leetcode 劍指 Offer 14- I. 剪繩子

0.code

class Solution {
    public int cuttingRope(int n) {
        int max = 0;
        for(int i=1;i<=n-1;i++){
            int ans = cuttingRopeHelp(i,n);
            max = max>ans?max:ans;
        }
        return max;
    }
    public int cuttingRopeHelp(int i,int n){
        int avg = n/(i+1);
        int res = n%(i+1);
        int re = 1;
        for(int j=1;j<=res;j++){
            re = re*(avg+1);
        }
        for(int j=res+1;j<=(i+1);j++){
            re = re*avg;
        }
        return re;
    }
}
class Solution {
    public int cuttingRope(int n) {
        int[] ans = new int[n+1];
        for(int i=0;i<=n;i++){
            ans[i]=0;
        }
        return cuttingRopeHelp(ans,n);
    }
    public int cuttingRopeHelp(int[] ans,int n){
        // 特殊情況
        if(n == 2){
            return 1;
        }
        if(ans[n]!=0){
            return ans[n];
        }
        int res = 0;
        for(int i = 2; i < n; i++){
            res = Math.max(res, Math.max(i * cuttingRopeHelp(ans,n-i), i * (n-i)));
        }
        ans[n]=res;
        return res;

    }
    
}
?著作權歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容