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