剪绳子问题

剪绳子问题


剪绳子问题
python

class Solution:
    def cuttingRope(self, n: int) -> int:
        # # dp法一
        # dp = [0] *(n+1)
        # dp[2] = 1
        # for i in range(3,n+1):
        #     for j in range(1,i//2+1):
        #         dp[i] = max(max(dp[i],max(j * dp[i-j],j*(i-j))),(i-j)*dp[j])
        # return dp[n]

        # # 改良法一
        # if n == 2:
        #     return 1
        # if n == 3:
        #     return 2
        # dp[2] = 2
        # dp[3] = 3
        # for i in range(4,n+1):
        #     for j in range(2,i//2+1):
        #         dp[i] = max(dp[i],dp[i-j]*dp[j])
        # return dp[n]

        # 贪心
        res = 1
        if n < 4:
            return n-1
        while n > 4:
            res *= 3
            n -= 3
        return res *n
        

java

class Solution {
    public int cuttingRope(int n) {
        // 动态规划
        int dp[] = new int[n+1];
        if (n<4){
            return n-1;
        }
        dp[2] = 2;
        dp[3] = 3;
        for(int i = 0;i < n+1;i++){
            for(int j = 2;j < i/2 +1;j++){
                dp[i] = Math.max(dp[i],dp[j]*dp[i-j]);
            }
        }
        return dp[n];
        // // 贪心
        // if (n<4){
        //     return n-1;
        // }
        // int result = 1;
        // while (n > 4){
        //     n =n-3;
        //     result = result*3;
        
        // }
        // return n * result;
    }
}

go

func cuttingRope(n int) int {
    dp := make([]int,n+1)
    if n < 4{
        return n-1
    }
    dp[2] = 2
    dp[3] = 3
    for i:= 4;i<n+1;i++{
        for j:=2;j<i/2+1;j++{
            if dp[i] < dp[j] * dp[i-j]{
                dp[i] = dp[j] * dp[i-j]
            }
        }
    }
    return dp[n]
    // res := 1
    // if n < 4{
    //     return n-1
    // }
    // res := 1

    // for{
    //     if n <= 4{
    //         break
    //     }
    //     n -= 3
    //     res *= 3

    // }

    // return res * n

}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值