343. 整数拆分
难度中等
给定一个正整数 n,将其拆分为至少两个正整数的和,并使这些整数的乘积最大化。 返回你可以获得的最大乘积。 示例 1:
输入: 2 输出: 1 解释: 2 = 1 + 1, 1 × 1 = 1。 示例 2:
输入: 10 输出: 36 解释: 10 = 3 + 3 + 4, 3 × 3 × 4 = 36。 说明: 你可以假设 n 不小于 2 且不大于 58。
思路1.0:印象里将整数拆分相乘以得到最大乘积,最优选择是拆成 3。 代码1.0(已过)
class Solution {
public:
int integerBreak(int n
) {
if(n
==2) return 1;
else if(n
==3) return 2;
int quo
= n
/ 3;
int rmd
= n
% 3;
if (rmd
== 1) return pow(3, quo
- 1) * 4;
else if (rmd
== 2) return pow(3, quo
) * 2;
return pow(3, quo
);
}
};