剪绳子【Java版】

剪绳子

http://www.nowcoder.com/practice/57d85990ba5b440ab888fc72b0751bf8

方法一:数学函数求导法

【总体思路】构造函数求导,得到:m=n/e (小数的情况下),也就是说尽量拆成一堆:2、3(最接近e的整数)

数学函数求导法:针对性规律
result= f(m) = (n/m) ^m,设n为定值,m为自变量,f(m)为乘积结果。
max{ f(m) }= max{ ln f(m) },取对数。
求 ln f(m)= m*( ln n- ln m )最值点的m值,求导并令f(m)'=0,得到m=n/e.
e=2.718,然后因为取整数,所以是拆成一堆2、3;
具体看下:4>>>2x2;5>>>2x3;6>>>3x3 符合分析的结果。

public class Solution {
    public int cutRope(int target) {
        if(target == 2)return 1;//因为题目要求最少拆成2份
        if(target == 3)return 2;
        int res = 1;
        while(target > 4 ){//target剩<=4时,三种情况:4=>2*2=4; 3=>3; 2=>2; (-=3 不存在1)
            target -= 3;
            res *= 3;
        }
        return res * target;//三种情况合并处理
    }
}//时间O(N),空间O(1)

方法二:动态规划

【总体思路】dp[] 存一步步的最优 + 找到 递推公式

public class Solution {
    int[] dp = new int[60];
    public int cutRope(int target) {
        if(target == 2) return 1;
        if(target == 3) return 2;//这里的策略不同,要单独拎出来
        dp[2] = 2;
        dp[3] = 3;//在target>=4的前提下,dp[]数组2~3对应的值(不必强制分两段)
        for(int i=4; i<=target; ++i){
            int max = Integer.MIN_VALUE;
            for(int j=2; j<=i-1; ++j){//果然,dp的本质是穷举
                if(max < dp[j]*(i-j)) max = dp[j]*(i-j);//动态规划重点是找到=>【最优子结构的递推公式】
            }//另一种递推:将上一行的(i-j)换成dp[i-j]
            dp[i] = max;
        }
        return dp[target];
    }
}//时间O(N^2)  空间O(N)
《剑指Offer-Java题解》 文章被收录于专栏

《剑指Offer-Java题解》

全部评论

相关推荐

评论
1
收藏
分享

创作者周榜

更多
正在热议
更多
# 春招至今,你的战绩如何? #
10895次浏览 93人参与
# 你的实习产出是真实的还是包装的? #
1936次浏览 42人参与
# 巨人网络春招 #
11358次浏览 223人参与
# 军工所铁饭碗 vs 互联网高薪资,你会选谁 #
7605次浏览 43人参与
# 简历第一个项目做什么 #
31722次浏览 338人参与
# 重来一次,我还会选择这个专业吗 #
433504次浏览 3926人参与
# MiniMax求职进展汇总 #
24091次浏览 309人参与
# 当下环境,你会继续卷互联网,还是看其他行业机会 #
187176次浏览 1122人参与
# 牛客AI文生图 #
21442次浏览 238人参与
# 不考虑薪资和职业,你最想做什么工作呢? #
152419次浏览 888人参与
# 研究所笔面经互助 #
118955次浏览 577人参与
# 简历中的项目经历要怎么写? #
310295次浏览 4216人参与
# AI时代,哪些岗位最容易被淘汰 #
63741次浏览 826人参与
# 面试紧张时你会有什么表现? #
30508次浏览 188人参与
# 你今年的平均薪资是多少? #
213111次浏览 1039人参与
# 你怎么看待AI面试 #
180086次浏览 1258人参与
# 高学历就一定能找到好工作吗? #
64329次浏览 620人参与
# 你最满意的offer薪资是哪家公司? #
76515次浏览 374人参与
# 我的求职精神状态 #
448107次浏览 3129人参与
# 正在春招的你,也参与了去年秋招吗? #
363447次浏览 2638人参与
# 腾讯音乐求职进展汇总 #
160661次浏览 1112人参与
# 校招笔试 #
471054次浏览 2964人参与
牛客网
牛客网在线编程
牛客网题解
牛客企业服务