前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >剑指offer - 剪绳子 II - JavaScript

剑指offer - 剪绳子 II - JavaScript

作者头像
心谭博客
发布2020-04-21 10:45:25
5460
发布2020-04-21 10:45:25
举报
文章被收录于专栏:YuanXin

题目描述:给你一根长度为 n 的绳子,请把绳子剪成整数长度的 m 段(m、n 都是整数,n>1 并且 m>1),每段绳子的长度记为 k[0],k[1]...k[m] 。请问 k[0]*k[1]*...*k[m] 可能的最大乘积是多少?例如,当绳子的长度是 8 时,我们把它剪成长度分别为 2、3、3 的三段,此时得到的最大乘积是 18。

答案需要取模 1e9+7(1000000007),如计算初始结果为:1000000008,请返回 1。

提示:2 <= n <= 1000

题目分析

本题的求解思路和LeetCode 343.整数拆分几乎一样,有动态规划和贪心法两种解法,具体请看这篇文章:《LeetCode 343.整数拆分 - JavaScript》

解法:过程中取模

和 Leetcode343 不同的是,本题中的 n 的取值范围很大,需要对结果进行取模。以贪心法的思路为例,如果直接计算 n 中 3 的个数 a,然后计算 3 的 a 次方,最后再取模,那么可能会出错。

正确的做法是:利用取模运算的性质,在过程中对每一步结果取模,这样保证每一步结果都不会溢出。

代码实现如下:

代码语言:javascript
复制
// ac地址:https://leetcode-cn.com/problems/jian-sheng-zi-ii-lcof/
// 原文地址:https://xxoo521.com/2020-02-15-jian-sheng-zi-ii-lcof/

/**
 * @param {number} n
 * @return {number}
 */
var cuttingRope = function(n) {
    if (n <= 3) return n - 1;

    let res = 1;
    while (n > 4) {
        n -= 3;
        res = (res * 3) % 1000000007;
    }
    return (n * res) % 1000000007;
};

时间复杂度是$O(N)$,空间复杂度是$O(1)$。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2020-02-15,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 题目分析
  • 解法:过程中取模
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档