博客
关于我
整数拆分
阅读量:203 次
发布时间:2019-02-28

本文共 531 字,大约阅读时间需要 1 分钟。

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

示例 1:

输入: 2输出: 1解释: 2 = 1 + 1, 1 × 1 = 1。

示例 2:

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

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

来源:力扣(LeetCode) 链接:https://leetcode-cn.com/problems/integer-break

著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

分析:

尽可能将n分解成3和2,并且最多只能有两个2,此时乘积最大

class Solution {   public:    int integerBreak(int n) {           if(n<=3) return 1*(n-1);        int p=1;        while(n>=5)        {               n-=3;            p*=3;        }        return p*n;    }};

如有问题,欢迎在评论区提问

你可能感兴趣的文章
Mysql缓存调优的基本知识(附Demo)
查看>>
mysql自增id超大问题查询
查看>>
mysql进阶 with-as 性能调优
查看>>
mysql部署错误
查看>>
MySQL锁与脏读、不可重复读、幻读详解
查看>>
MySQL集群解决方案(4):负载均衡
查看>>
mysql面试题学校三表查询_mysql三表查询分组后取每组最大值,mysql面试题。
查看>>
MySQL面试题集锦
查看>>
mysql颠覆实战笔记(八)--mysql的自定义异常处理怎么破
查看>>
mysql驱动、durid、mybatis之间的关系
查看>>
mysql驱动支持中文_mysql 驱动包-Go语言中文社区
查看>>
MySQL高可用切换_(5.9)mysql高可用系列——正常主从切换测试
查看>>
MYSQL高可用集群MHA架构
查看>>
MySQL高级-MySQL并发参数调整
查看>>
MySQL高级-MySQL查询缓存优化
查看>>
MySQL高级-SQL优化步骤
查看>>
MySQL高级-视图
查看>>
MySQL高级-触发器
查看>>
mysql高级查询~分页查询
查看>>
MySQL(2)DDL详解
查看>>