算法学习记录(四)--剑指offer题目归类

目前刚把链表部分学习完,个人感觉大模块的题目放在一块学习比较好
所以把题目分类一下:

  1. 数组--9题
面试题3:二维数组中的查找

面试题14:调整数组顺序使得奇数位于偶数前面

面试题29:数组中出现超过一半的数字

面试题30:最小的k个数

面试题33:把数组排成最小的数

面试题36:数组中的逆序对

面试题40:数字在排序数组中出现的次数

面试题51:数组中重复的数字

面试题52:构建乘积数组

  1. 字符串--10题
面试题4:替换空格

面试题12:打印1到最大的n位数

面试题28:字符串的排列

面试题32:从1到n整数中1出现的次数

面试题35:第一个只出现1次的字符

面试题42:反转单词顺序以及坐旋转字符串

面试题49:把字符串转换成整数

面试题53:正则表达式匹配

面试题54:表示数值的字符串

面试题55:字符流中第一个不重复的字符
  1. 栈/队列--3题
面试题7:用两个栈实现队列

面试题21:包含min函数的栈

面试题22:栈的压入、弹出序列
  1. 查找/排序--1题
面试题8:旋转数组中的最小数字
  1. 链表--9题
面试题5:从尾到头打印链表

面试题13:在O(1)时间删除链表结点

面试题15:链表中倒数第k个结点

面试题16:反转链表

面试题17:合并两个排序的链表

面试题26:复杂链表的复制

面试题37:两个链表的第一个公共结点

面试题56:链表中环的入口结点

面试题57:删除链表中重复的结点
  1. 二叉树--16题
面试题6:重建二叉树

面试题18:树的子结构

面试题19:二叉树镜像

面试题23:从上往下打印二叉树

面试题24:二叉搜索树的后序遍历

面试题25:二叉树中和为某一值的路径

面试题27:二叉搜索树与双向链表

面试题39:二叉树的深度

面试题50:树中两个节点的最低公共祖先

面试题58:二叉树的下一个节点

面试题59:对称的二叉树

面试题60:把二叉树打印成多行

面试题61:按之字形顺序打印二叉树

面试题62:序列化二叉树

面试题63:二叉搜索树的第k个结点

面试题65:滑动窗口的最大值
  1. 动态规划--4题
面试题9:斐波那契数列

面试题31:连续子数组的最大和

面试题34:丑数

面试题45:圆圈中最后剩下的数字
  1. 数值操作--9题
面试题10:二进制中1的个数

面试题11:数值的整数次方

面试题20:顺时针打印矩阵

面试题41:和为s的两个数字VS和为s的连续正数序列

面试题43:n哥骰子的点数

面试题44:扑克牌顺子

面试题46:求1+2+3+.......+n

面试题47:不用加减乘除做加法

面试题64:数据流中的中位数

  1. 回溯法--2题
面试题66:矩阵中的路径

面试题67:机器人的运动范围

以上总共加起来有63题,准备按照题数从大到小顺序学习

2. 学习顺序

二叉树->字符串->链表->数组->数值操作->动态规划->栈队列->回溯法->查找排序

3. 计划安排
归类 时间 频率
二叉树 2周 1题/d
字符串 5天 2题/d
链表 完成 完成
数组 3天 3题/d
数值操作 3天 3题/d
动态规划 4天 1题/d
栈队列 1天 3题
回溯法 2天 1题/d
查找排序 3天 1

总共需要:35天,理想情况下;预计还得45d左右

参考剑指offer题目分类

你可能感兴趣的:(算法学习记录(四)--剑指offer题目归类)