代码随想录算法训练营第四十五/四十六天 | 背包问题

博主分享了在解决编程题目,如爬楼梯、零钱兑换、完全平方数和单词拆分时的思考过程和实现感想。在爬楼梯问题中未能意识到排列的重要性,零钱兑换的代码简洁性不足,完全平方数的解决方案效率尚可,而单词拆分则困扰于字符串操作,尝试了不同的优化方法。
摘要由CSDN通过智能技术生成

背包问题

题目

70. 爬楼梯
322. 零钱兑换
279.完全平方数
139.单词拆分

对题目的想法

爬楼梯和单词拆分没有什么思路,尤其是单词拆分,甚至想到要不要用KMP算法查询字符串。

实现中/后的感想

  1. 爬楼梯没有意识到是一个排列问题,因为先上n级台阶再上m级台阶 ( n , m ) (n, m) (n,m),和先上m级台阶再上m级台阶 ( m , n ) (m,n) (m,n)并不一样。
  2. 零钱兑换几乎一次过,除了特殊情况 a m o u n t = 0 amount = 0 amount=0时没有考虑。不过看了随想录之后感觉代码不够简洁。
  3. 完全平方数其实没有觉得这是个背包问题,用了比较直观的想法,但是效率也没有差很多。
  4. 单词拆分花了很长时间:
    • 字符串拆分不够熟练。使用的是new String(char[] arr, int offset, int count)但是count一直出界,因为没有想用dp数组。
    • 用了一个额外的链表记录所有dp[i] = true的位置,从而每次遍历都可以从这些true的地方开始,而不用遍历每一个"物品“。
    • 直观感觉是要比使用一个dp数组要快一点点,但并没有做具体的比较,明天再测试一下。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值