所有题目单独整理的版本存储在这里, 点击题目名字可以跳转到牛客网的成功提交记录,点击python可以看到存储库中的对应求解代码。
《剑指offer》牛客网刷题总结
点击题目可以跳转到牛客网上对应的AC提交记录,具体的python文件存储在库中。
Title | Solution | Time | Space | Category |
---|---|---|---|---|
二维数组中的查找 | Python | O(n) | O(1) | 数组 |
替换空格 | Python | O(n) | O(1) | 字符串 |
从尾到头打印链表 | Python | O(n) | O(1) | 链表 |
斐波那契数列 | Python | O(n) | O(1) | 循环》递归 |
跳台阶 | Python | O(n) | O(1) | 循环》递归 |
用两个栈实现队列 | Python | _ | _ | 栈、队列 |
变态跳台阶 | Python | O(1) | O(1) | 循环 |
旋转数组的最小数字 | Python | O(logn) | O(1) | 查找 |
二进制中1的个数 | Python | O(n) | O(1) | 位运算 |
重建二叉树 | Python | O(logn) | O(1) | 二叉树 |
链表中倒数第k个结点 | Python | O(n) | O(1) | 链表,代码完整性 |
矩形覆盖 | Python | O(n) | O(1) | 动规 |
反转链表 | Python | O(n) | O(1) | 链表、代码完整性 |
调整数组顺序使奇数位于偶数前面 | Python | O(nlogn) | O(1) | 数组 |
数值的整数次方 | Python | O(logn) | O(1) | 代码完整性 |
合并两个排序的链表 \\ 进阶题目:合并k个有序链表 | Python | O(n+m) | O(1) | 代码鲁棒性 |
二叉树的镜像 | Python | O(logn) | O(1) | 二叉树 |
树的子结构 | Python | O(m)~O(n*m) | O(1) | 代码鲁棒性 |
从上往下打印二叉树 | Python | O(n) | O(n) | 二叉树 |
栈的压入、弹出序列 | Python | O(n) | O(1)~O(n) | 栈 |
包含min函数的栈 | Python | O(1) | O(n) | 栈 |
顺时针打印矩阵 | Python | O(n*m) | O(1) | 数组 |
数组中出现次数超过一半的数字 | Python | O(2n) | O(1) | 数组 |
二叉搜索树的后序遍历序列 | Python | O(nlogn) | O(1) | 二叉树 |
最小的K个数 | Python | O(n) | O(1) | 数组 |
连续子数组的最大和 | Python | O(n) | O(1) | 动规 |
二叉树中和为某一值的路径 | Python | O(logn) | O(1) | 二叉树 |
二叉树的深度 | Python | O(logn) | O(1) | 二叉树 |
第一个只出现一次的字符位置 | Python | O(n) | O(1) | 字符串 |
求1+2+3+...+n | Python | O(n) | O(1) | 构造函数 |
字符串的排列 | Python | O(n^2) | O(1) | 递归 |
两个链表的第一个公共结点 | Python | O(n+m) | O(1) | 链表 |
数字在排序数组中出现的次数 | Python | O(logn) | O(1) | 二分 |
复杂链表的复制 | Python | O(n) | O(1) | 链表 |
数组中只出现一次的数字 | Python | O(n) | O(1) | 位运算 |
丑数 | Python | O(n) | O(n) | 数学 |
数组中重复的数字 | Python | O(n) | O(1) | 数组 |
把数组排成最小的数 | Python | O(nlogn) | O(1) | 数组 |
和为S的两个数字 | Python | O(n) | O(1) | 双指针 |
整数中1出现的次数(从1到n整数中1出现的次数) | Python | O(logn) | O(1) | 数学规律 |
左旋转字符串 | Python | O(n) | O(1) | 字符串 |
平衡二叉树 | Python | O(logn) | O(1) | 二叉树 |
翻转单词顺序列 | Python | O(n) | O(1) | 字符串 |
二叉搜索树与双向链表 | Python | O(n) | O(1) | 二叉树、双向链表 |
和为S的连续正数序列 | Python | O(n) | O(1) | 双指针 |
不用加减乘除做加法 | Python | O(1) | O(1) | 位运算 |
删除链表中重复的结点 | Python | O(n) | O(1) | 链表 |
链表中环的入口结点 | Python | O(n) | O(1) | 链表 |
数组中的逆序对 | Python | O(nlogn) | O(n) | 归并 |
把字符串转换成整数 | Python | O(n) | O(1) | 字符串 |
对称的二叉树 | Python | O(logn) | O(1) | 二叉树 |
扑克牌顺子 | Python | O(1) | O(1) | 数学规律 |
孩子们的游戏(圆圈中最后剩下的数) | Python | O(n) | O(1) | 动规、环形链表 |
二叉树的下一个结点 | Python | O(n) | O(1) | 二叉树 |
构建乘积数组 | Python | O(n) | O(n) | 数组 |
把二叉树打印成多行 | Python | O(n) | O(n) | 二叉树 |
二叉搜索树的第k个结点 | Python | O(nlogn) | O(n) | 树 |
按之字形顺序打印二叉树 | Python | O(n) | O(n) | 二叉树 |
字符流中第一个不重复的字符 | Python | O(n) | O(1) | 字符串 |
滑动窗口的最大值 | Python | O(n) | O(1) | 双向队列 |
表示数值的字符串 | Python | O(1) | O(1) | 正则表达式 |
机器人的运动范围 | Python | O(n^2) | O(n^2) | 回溯法 |
正则表达式匹配 | Python | O(n) | O(1) | 正则表达式 |
矩阵中的路径 | Python | O(n^2) | O(1) | 回溯法 |
序列化二叉树 | Python | O(logn) | O(1) | 二叉树 |
数据流中的中位数 | Python | 插入O(logn) \ 中位数O(1) | O(1) | 树、堆 |
所有题目单独整理的版本存储在这里, 点击题目名字可以跳转到牛客网的成功提交记录,点击python可以看到存储库中的对应求解代码。