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

文章目录

  • 背包问题
    • 题目
    • 对题目的想法
    • 实现中/后的感想

背包问题

题目

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数组要快一点点,但并没有做具体的比较,明天再测试一下。

你可能感兴趣的:(算法)