剑指offer转载的

剑指offer终于三刷完结,本篇打算做一个简单的总结,我的做法是看着题目目录,直接思考题目内容以及核心解题思路,希望做到看到题目直接映射解题思路,然后对所有题目做一个简单的分类总结,进行反思。然后剑指offer会暂时告一段落,下一阶段集中精力battle leetcode。

3.数组中重复数字:每个位置放置数字与下标对应相等 O(n)

4.二维数组中的查找:左下角开始比较 O(m+n) (微软)

5.替换空格:python直接替换

6.从尾到头打印链表:python insert函数

7.重建二叉树:前序中序遍历特点递归

8.二叉树的下一个节点:根据中序遍历特点,按有无右子树分情况讨论

9.两个栈实现队列:栈的特点

10.斐波那契数列:递归思想,循环方法自下而上计算 O(n) (oppo)

11.旋转数组最小数字:二分查找,考虑left,right,mid三个下标值相同情况。O(logn)

12.矩阵中的路径:回溯法,递归解决,需要’#’标记走过的路径,回溯时变为原来的字母

13.机器人的运动范围:回溯法,递归解决

15.二进制中1的个数:位运算,将一个整数减去1再和原来整数做位与运算,相当于把整数二进制最右边的1变为0

16.数值的整数次方:递归 O(logn)

17.打印从1到最大的n位数:dfs,大数问题

18.删除链表中重复节点:设置dummy头结点,指针操作

21.调整数组顺序使奇数位于偶数前面:双指针 O(n)

22.链表中倒数第k个节点:双指针,一个指针先走k步

23.链表中环的入口节点:快慢指针,数学证明 (百度)

24.反转链表:两种方法,指针调整

25.合并两个排序链表:新建一个链表;在原链表基础上合并

26.树的子结构:两个递归,一个遍历A树节点,找到与B树根节点值相同的节点;一个遍历以A树节点为根结点的子树和B树,判断其是否包括B

27.二叉树的镜像:递归考察先序遍历;非递归考察层序遍历

28.对称的二叉树:递归

29.顺时针打印矩阵:设置up,down,left,right四个位置变量,顺时针遍历

30.包含min函数的栈:维护一个栈,栈顶元素永远是最小值

31.栈的压入弹出序列:栈的性质

32:从上到下打印二叉树:层序遍历

33.二叉搜索树的后续遍历序列:后续遍历特点,递归解决

34.二叉树中和为某一值的路径:dfs记录每一条路径和

35.复杂链表的复制:指针操作,三步走战略:复制原始链表节点,设置节点random指针,链表拆分

36.二叉搜索树与双向链表:中序遍历的考察

37.序列化二叉树:先序遍历及利用序列构造树

38.字符串的排列:全排列问题,dfs解决

39.数组中出现次数超过一半的数字:partition函数可以实现O(n)时间找到第k大的数O(n);利用数组性质,两两相消得到最后的数字 O(n)

40.最小的k个数:partition函数找到第k个数位置,返回该数左边k个数 O(n);最大堆,维护大小为k的最大堆 O(nlogk)

41.数据流中的中位数:最小堆与最小堆,维护一个最大堆,一个最小堆,最大堆中所有元素小于最小堆中所有元素,两个堆元素保持相同,堆顶元素即为中位数 O(logn)

42.连续子数组最大和:动态规划 O(n)

44.把数组排成最小的数:partition函数排序,设置比较大小规则 O(nlogn)

46.数字翻译成字符串:动态规划 O(n)

47.礼物的最大价值:动态规划

48.最长不含重复子串的子字符串:动态规划 O(n)

49.丑数:动态规划

50.第一个只出现一次的字符:哈希表 O(n)

51.数组中的逆序对:归并排序的应用 O(nlogn)O(n)

52.两个链表的第一个公共节点:遍历至尾节点跳到另一个链表头结点继续遍历 O(m+n)(百度)

53.数字在排序数组中出现的次数:二分查找 O(logn)

54.二叉搜索树的第k大节点:二叉搜索树的中序遍历

55.二叉树的深度:后序遍历

56.数组中只出现一次的两个数字:位运算的考察

57.和为s的数字:双指针 O(n)

58.左旋转字符串:多次翻转

59.滑动窗口最大值:维护最大值队列 O(n)

61.扑克牌中的顺子:比较0的个数与空缺个数

62.圆圈中最后剩下的数字:环形链表 O(mn);约瑟夫环 O(n)

63.股票的最大利润:动态规划 O(n)

67.字符串转化为整数:思维全面性

68.树中两个节点最低公共祖先:递归;非递归 (微软)

分类:

链表:6. 18. 22. 23. 24. 25. 35. 36. 52. 62.

树:7. 8. 26. 27. 28. 32. 33. 34. 37. 54. 55. 68.

动态规划:10. 42. 46. 47. 48. 49. 63.

递归:12. 13.

数组:3. 4. 11. 17. 21. 45. 51. 53.

字符串:5. 38. 58. 67.

位运算:15. 56. 65.

其他:9. 16. 29. 30. 31. 39. 40. 41. 43. 50. 57. 59. 61.

链表、树、动态规划、数组、字符串的问题是重中之重,需要重点掌握,其他比如栈和队列,位运算等问题出题频率相对较低,可记忆一下典型问题。

2019.4.20

四刷完结,以后应该不会在看了。

2019.9.15

编辑于 2019-09-15

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值