《剑指offer》14--剪绳子(整数拆分)[C++]

目录

题目描述

贪心算法

输出结果


题目描述

把一根绳子剪成多段,并且使得每段的长度乘积最大。

给定一个正整数 n,将其拆分为至少两个正整数的和,并使这些整数的乘积最大化。 返回你可以获得的最大乘积。

示例 1:

输入: 2

输出: 1

解释: 2 = 1 + 1, 1 × 1 = 1。

示例 2:

输入: 10

输出: 36

解释: 10 = 3 + 3 + 4, 3 × 3 × 4 = 36。

说明: 你可以假设 n 不小于 2 且不大于 58。

贪心算法

设n分成k份时乘积最大,则要令d (n/k)^k / dk等于零,或令d k*log(n/k) / dk等于零。求出来k=n/e,所以每份应尽量接近e=2.7,因此尽量凑3。

尽可能多剪长度为 3 的绳子,并且不允许有长度为 1 的绳子出现。如果出现了,就从已经切好长度为 3 的绳子中拿出一段与长度为 1 的绳子重新组合,把它们切成两段长度为 2 的绳子。

证明:当 n >= 5 时,3(n - 3) - n = 2n - 9 > 0,且 2(n - 2) - n = n - 4 > 0。因此在 n >= 5 的情况下,将绳子剪成一段为 2 或者 3,得到的乘积会更大。又因为 3(n - 3) - 2(n - 2) = n - 5 >= 0,所以剪成一段长度为 3 比长度为 2 得到的乘积更大。

cpp 复制代码
#include<iostream>
#include<vector>
using namespace std;

//计算各数位的和
class Solution {
public:
    int integerBreak(int n) {
        if (n < 2) return 0;
        if (n == 2) return 1;
        if (n == 3) return 2;
        int T3 = n / 3;
        if (n % 3 == 1) T3--;
        int T2 = (n - T3 * 3) / 2;
        return ((int)pow(3, T3)) * ((int)pow(2, T2));
    }
};


int main()
{
    Solution test;
    int result = test.integerBreak(10);
    std::cout << "mian result:" << result << std::endl;

	return 0;
}

输出结果

相关推荐
水云桐程序员1 小时前
C++可以写手机应用吗
开发语言·c++·智能手机
测试员周周1 小时前
【AI测试智能体】为什么传统测试方法对智能体失效?
开发语言·人工智能·python·功能测试·测试工具·单元测试·测试用例
RSTJ_16252 小时前
PYTHON+AI LLM DAY THREETY-NINE
开发语言·人工智能·python
赏金术士3 小时前
Kotlin 从入门到进阶 之函数模块(核心基础)(二)
android·开发语言·kotlin
加号35 小时前
【Qt】 应用程序发布:依赖库拷贝与部署指南
开发语言·qt
('-')5 小时前
八股复习2:Java Array list和Linked list
java·开发语言
小黄人软件5 小时前
C++读写编辑CSV文件示例源码 用于数据导入导出,比Excel好使
开发语言·c++·excel
郭涤生5 小时前
C++各个版本的性能和安全性总结
开发语言·c++
wljy17 小时前
二、静态库的制作和使用
linux·c语言·开发语言·c++
道剑剑非道7 小时前
FFmpeg 6.0 实战:用 C++ 封装摄像头采集与 RTSP 推流
开发语言·c++·ffmpeg