LeetCode 上不会的
Reverse Integer
Single Number II
斐波那契数列 非递归算法
Maximum Subarray 维持最大值
Integer to Roman
Sort Colors
Populating Next Right Pointers in Each Node 怎么样控制一层
Gray Code
Generate Parentheses
Binary Tree Postorder Traversal
Best Time to Buy and Sell Stock 倒着来
Set Matrix Zeroes
Pascal‘s Triangle II 正方向读和反方向读保持不变的区别
Search in Rotated Sorted Array II
Trapping Rain Water 抓住数组的特性 可以排序 可以拿出最大值或者最小值来做参考
Unique Binary Search Trees II 不是溯源的去找根节点,而是重新生成根节点
Anagrams 对于相似的字符串或数组一样,经过排序则是一样的,另外判断是否已经存在一次了,使用标记数组后者Map
Distinct Subsequences 动态规划 通过递推公式确定动态规划的式子
First Missing Positive 数组自操作,通过交换,数值成了索引 A[i] A[A[i]-1] 真是一道好题啊
Word Break 动态规划问题
Largest Rectangle in Histogram 完全没有思路
Maximum Product Subarray
Candy 从波峰到波谷 从波峰到波谷
Scramble 三维数据二维看~~一些corner case 两个字符串的动态规划问题
往往是用一个字符串的长度变化做横坐标,另外一个字符串的长度变化做纵坐标,左右摇摆,上下摇摆,诸如此类方法。如果发现二维还不能解决问题,那么好,我就再加上一维变成三维动态规划问题,如果是一个字符串问题,那就更简单了,横纵坐标都表示的是这个字符串的长度变化
Longest Valid Parentheses 测试用例没写全而且题意没弄明白,所以一直测试过不了,不过倒是学习了不少的新方法,不断的测试,测试你妹啊
Permutation Sequence
解法简直
华丽丽 厉害 凸显编程之美~~数学的思维
Longest Valid Parentheses
不得不说自己距离
动态规划还有好长的路要走,没有了解到核心的方法和内容,做完之后要再整理一番
Find Minimum in Rotated Sorted Array II 这TM的才是二分查找,能用到如此精彩
Divide Two Integers 数字要考虑数字是正数 负数 0 负数转换成正数的时候 数字会出现溢出的现象 (2^k)*除数
<= 当前被除数 <(2^(k+1))*除数
数学真是一种美
MinStack 网易的面试题,当时会了,现在又不会了,真是为自己的智商担心
Maximum Gap 这个题有两个好的地方,所谓平均值的含义就是必定有比平均值大的也有比平均值小的,如何计算桶的idx 当前数字:num =
min + k*bucket_size 由此求idx
对于int 类型的数据
进行取绝对值的时候,一定要记得强转成Long 在进行abs,因为Int负数的最小值,取绝对值后,int类型是存不了的。
BFS的模板 Queue
LinkedList Boolean isVisited[] ;
Minimum Window Substring 通过HashTable确定字母的数量,然后加上两个指针来回访问,通用的模板。
Find Peak
Element 原来二分查找随便用,是指上升沿和下降沿的问题啊。又进一步理解了二分查找。抓住特点啊
特点啊 右移的操作用>>1
不要误写成 2
小结:
深度递归(DFS)à考虑可不可以用动态规划来做
到当前为止 字符串往往是到当前字符为止,更新Dp数组(要解决问题的数组),解决方法循环遍历之前的已经计算完的数据解决或者通过对之前的数组进行相加等运算操作进行处理。
划分集合问题,当考虑要遍历所有的子串,所有的自数组问题的时候,可以考虑使用动态规划,从
长度为1的字串或子数组开始,一直遍历到长度问n的字串或者子数组。
链表内部的特点啊,凡是不能该表原始链表的结构,考虑一下,可不可以转换成数学问题,追击问题啊之类的。一个跑一个追,两个一起跑。不让增加空间,只能有开辟两个指针了有木有。真是机智到不行。
思路不好:
Remove Nth Node
From End of List 双指针
Longest
Consecutive Sequence set集合的使用
3Sum Closest 先排序
Pow(x, n) 移位操作 移动一位的含义
收获:
当不知道怎么对数组进行切分时,往往里面存着对应的数学关系。
回溯就是 选或者不选+递归 也就是DFS DFS把大事化小,小事化了
递归常常结合 交换, 选或者不选 相同的模式 再次进行
除数是0 的情况也得catch 到
动态规划往往可以用填表法完成,同样填表法也有助于发现动态规划的函数表达式
在链表题中,灵活地运用虚拟表头会减少很多工作量
2 链表题往往在收尾处要多判断一下,防止corner case
不满足当前的时间复杂度,还能更快一点,更快一点,分治等策略。
对于计算在一个循环,如循环一个数组或者字符串,在循环中记录一个Max,一定要在循环结束后再一次判断 结尾处是否还需要再次更新Max(开头和结尾是两个需要重要判断的地方)
链表中 常用快慢指针 链表的反转 链表的合并 都是常考的内容
Time Limited 主要有两个原因 1、对于含有循环的例子 有可能有死循环;2、对于递归的问题,有可能是因为递归的返回值弄的不对,导致一直递归无法结束。
值得重写的Code 不太熟
Insertion Sort
List
Remove Duplicates
from Sorted List II while true 的应用 pre cur next 三者的应用
Recover Binary Search
Tree 论中序 前序 后序遍历的特点
待字闺中:
统计数组中每一个出现的次数的问题 A[i] = A[i] * n ; A[A[i]/n]++;A[i]%n的应用
母串中是否存在字串的任意排列 对于排序后的母串和字串相同--字符串的特点;
树的高度问题 回溯也是一种递归