题解 | #剪绳子#

剪绳子

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-2行主修课程;不对口就不写 学历如果不占优势,可以把教育经历放到简历靠后的位置 三、实习/项目经历 如果没有实习经历,全部写项目经历 每条经历格式:项目名 + 岗位名 + 任职时间段 下面写三到五条工作内容 每条工作内容开头必须用四个字概括,加粗,后面跟一条完整描述 所有描述必须用STAR法则来写(情境-任务-行动-结果) 每一条都要有数据支撑和具体成果 四、个人优势 可以写获得的奖项、证书 如果奖项不够,就写你熟练掌握的技能 每条也要有具体数据或成果支撑,不能空泛堆砌 五、整体要求 一页纸,不要超过一页 个人信息只写名字加电话邮箱 贝贝试一下这个方式写简历,我虽然没收到offer,至少收到了好几轮面试
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务