《剑指offer》NO14 剪绳子 两种方法实现详解 <Java实现>

题目描述

把一根绳子剪成多段,并且使得每段的长度乘积最大。

贪心算法

//贪心算法  时间复杂度O(1)  空间复杂度O(1)

    //解题思路
        //当 n >= 5 时,可以证明 2(n - 2) > n 并且3(n - 3) > n,所以说当绳子剩下的长度大于或者等于5的时候
        //我们就把他剪成长度为3或者为2的绳子段。同时,3(n - 3) >= 2(n - 2)
        //所以我们应该尽可能去多剪长度为3的绳子段。

        //但是当n = 5 时 1 * 3 < 2 * 2 所以当绳子的长度为4的时候没必要剪,但是题目要求剪一刀
        //所以剪为 2  2。
        public int maxProductAfterCutting2(int n)
        {
            if (n < 2)
                return 0;
            if (n == 2)
                return 1;
            if (n == 3)
                return 2;
            if (n == 4)
                return 4;

            //计算给的数中个有多少个3
            int countOf3 = n / 3;

            //如果有4的话,就把这个3归还, 变为3 * 2 * 2。
            // 因为3 * 3 * 1 < 3 * 2 * 2
            if (n - countOf3 * 3 == 1)
                countOf3--;

            int countOf2 = (n - countOf3 * 3) / 2;
            return (int) ((Math.pow(3, countOf3)) * (Math.pow(2, countOf2)));

        }

动态规划

//动态规划  时间复杂度 O(n * n),空间复杂度 O(n)
    public int maxProductAfterCutting(int len)
    {
        if (len < 1) 
        	return 0;
        int[] product = new int[len + 1];
        product[1] = 0;
        for (int i = 2; i <= len; i++)
        {
            for (int j = 1; j < 2; j++)
            {
                            //更新product[i]             //找出(i - j)*j的最大值
                product[i] = Math.max(product[i],       Math.max((i - j) * j, product[j] * (i - j)));
            }
        }

 /*       或者这样写
        for (int i = 2; i <= len; i ++)
        {
            int max = 0;

            for (int j = 1; j < 2; j ++)
            {
                if(max < (i - j) * j)
                    max = (i - j) * j;
            }
            product[i] = max;
        }
*/
        return product[len];
    }
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值