题解 | #剪绳子#

剪绳子

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

这题首先需要注意的是 m>1, n>1. 拿到题目我是没有考虑到需要用动态规划, 后来在想暴力解的时候发现是可以用动态规划的, 于是就开始找规律. 其实动态规划的话找到状态转移方程比较重要, 但是我一开始没有去找, 而是在找规律.

n    = 2 3 4   5   6   7     8     9 
(m>=1) 2 3 2*2 2*3 3*3 3*2*2 3*3*2 3*3*3

所以我总结两个规律

  1. 2和3需要尽可能的多
  2. 3越多越好

比如说7, 如果只是331 = 9 < 322=12的, 而所有数字都可以使用2和3构成, 所以我就直接写代码, 在n<=3的时候特殊处理, 其余的就直接硬算, 在2 3的组合中选择3最多的, 这个思想可以得到状态转移方程:

dp(i) = 2*dp(i-2) if i-3<=1
dp(i) = 3*dp(i-3) if i-3>1

代码如下

#
# 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
#
# 
# @param number int整型 
# @return int整型
#
class Solution:
    def cutRope(self , number: int) -> int:
        # write code here
        if number <= 3:
            return number - 1
        dp = [0, 0, 2, 3]
        for i in range(4, number+1):
            if i-3 <= 1:
                dp.append(2*dp[i-2])
            else:
                dp.append(3*dp[i-3])
        return dp[-1]
    
全部评论

相关推荐

评论
1
收藏
分享

创作者周榜

更多
正在热议
更多
# 春招至今,你的战绩如何? #
6802次浏览 65人参与
# 你的实习产出是真实的还是包装的? #
1339次浏览 33人参与
# MiniMax求职进展汇总 #
23251次浏览 303人参与
# 军工所铁饭碗 vs 互联网高薪资,你会选谁 #
7120次浏览 37人参与
# 简历第一个项目做什么 #
31334次浏览 315人参与
# 当下环境,你会继续卷互联网,还是看其他行业机会 #
186557次浏览 1115人参与
# 巨人网络春招 #
11224次浏览 223人参与
# 研究所笔面经互助 #
118794次浏览 577人参与
# 面试紧张时你会有什么表现? #
30416次浏览 188人参与
# 简历中的项目经历要怎么写? #
309597次浏览 4167人参与
# 职能管理面试记录 #
10726次浏览 59人参与
# AI时代,哪些岗位最容易被淘汰 #
62775次浏览 750人参与
# 网易游戏笔试 #
6382次浏览 83人参与
# 把自己当AI,现在最消耗你token的问题是什么? #
7014次浏览 154人参与
# 腾讯音乐求职进展汇总 #
160447次浏览 1107人参与
# 从哪些方向判断这个offer值不值得去? #
56712次浏览 357人参与
# 正在春招的你,也参与了去年秋招吗? #
362761次浏览 2632人参与
# 你怎么看待AI面试 #
179447次浏览 1184人参与
# 小红书求职进展汇总 #
226924次浏览 1357人参与
# 你的房租占工资的比例是多少? #
92153次浏览 896人参与
# 校招笔试 #
467856次浏览 2955人参与
# 经纬恒润求职进展汇总 #
155724次浏览 1085人参与
牛客网
牛客网在线编程
牛客网题解
牛客企业服务