《剑指offer》牛客刷题
以下是我个人第一次刷《剑指offer》的代码,尽量下次刷的时候能够花式求解。
二维数组中的查找 | 从右上角开始找 |
替换空格 | 先算出替换后的长度,从后往前 |
从尾到头打印链表 | 使用栈,或者用vector的.insert(res.begin(), head->val); |
重建二叉树 | 根据中序遍历和前序遍历重建二叉树 |
用两个栈实现队列 | stack1用来进栈,stack2用来出栈。当stack2空的时候,去stack1中拿 |
旋转数组的最小数字 | 二分查找,当出现11111这种情况,只能一个个找 |
斐波那契数列 | 最好用循环,其次是记忆数组,最差是直接递归 |
跳台阶 | 跟斐波拉一样f(n) = f(n-1)+f(n-2); 不同的是 f(1)=1,f(2)=2; |
变态跳台阶 | return 2**(number-10 |
矩形覆盖 | 跟斐波拉契一样f(n)=f(n-1)+f(n-2) |
二进制中1的个数 | flag不断左移,知道flag=0。flag & n !=0, count++ |
数值的整数次方 | 写出比for循环更好的方法,就是&跟<< |
调整数组顺序使奇数位于偶数前面 | 找到奇数的个数,然后往后挪 |
链表中倒数第k个结点 | 好无聊的题目 |
反转链表 | 循环,用pre、next记录前一个和下一个指针的位置,实在不行就用栈 |
合并两个排序的链表 | 看到哪个值小的就加进去,然后继续把剩下的加进去 |
树的子结构 | 写多一个函数judge判断r1为根时候r2是否包含 |
二叉树的镜像 | 递归交换左右孩子 |
顺时针打印矩阵 | 记录打印过的位置 |
包含min函数的栈 | 用两个栈解决,一个存最小值 |
栈的压入、弹出序列 | 借用一个stack,遍历出栈顺序,如果入栈不等于出栈就压入栈 |
从上往下打印二叉树 | 层次遍历 |
二叉搜索树的后序遍历序列 | 小于根节点的都在左子树,大于根节点的都在右子树。然后递归判断左右子树 |
二叉树中和为某一值的路径 | 递归到尽头,判断是否符合条件 |
复杂链表的复制 | v1,v2存放原始和复制的指针。然后连接next跟randomOK啦。最大的缺点就是循环链表就不能复制了。 |
二叉搜索树与双向链表 | 将二叉搜索树拉直,左边为小右边为大,然后连接左边和根、右边和根。注意返回最小的节点才能通过测试用例。 |
字符串的排列 | 全排列 |
数组中出现次数超过一半的数字 | 哈希map |
最小的K个数 | 优先队列 |
连续子数组的最大和 | DP,f(n) = max(a[i], f(n-1)+a[i]) |
整数中1出现的次数(从1到n整数中1出现的次数) | 每个位数出现1的次数累加,把数分为前后两部分 |
把数组排成最小的数 | s1+s2<s2+s1判断 |
丑数 | 丑数p = 2 ^ x * 3 ^ y * 5 ^ z |
第一个只出现一次的字符位置 | 哈希map |
数组中的逆序对 | 归并排序,并且left+right+当前的逆序对 |
两个链表的第一个公共结点 | 哈希map |
数字在排序数组中出现的次数 | 二分查找k+0.5 - k-0.5 |
二叉树的深度 | dfs遍历二叉树 |
平衡二叉树 | 它是一棵空树或它的左右两个子树的高度差的绝对值不超过1,并且左右两个子树都是一棵平衡二叉树 |
数组中只出现一次的数字 | 将出现一次的2个数字分开,然后异或 |
和为S的连续正数序列 | 用begin和end两个指针 |
和为S的两个数字 | 用begin和end两个指针 |
左旋转字符串 | 字符串切片str.assign("ABC",1,1) |
翻转单词顺序列 | 将单词存在vector<string> v中,然后逆序叠加 |
扑克牌顺子 | 先排序,然后计算出0的个数,以便得到出0外的最大最小值。最大最小差>4就返回false,有重复就返回false |
孩子们的游戏(圆圈中最后剩下的数) | return (LastRemaining_Solution(n-1,m)+m)%n; |
求1+2+3+...+n | 求和公式 |
不用加减乘除做加法 | return Add(num1^num2, (num1&num2)<<1); |
把字符串转换成整数 | 溢出处理 0x7FFFFFFF(0111 1111 1111 1111)0x80000000(1000 0000 0000 0000) |
数组中重复的数字 | 哈希map |
构建乘积数组 | 不能用除法,那就构建一个二维数组,i==j时为1 |
正则表达式匹配 | 分情况讨论 |
表示数值的字符串 | 找出Ee、+-、.不符合条件的return false |
字符流中第一个不重复的字符 | 哈希map |
链表中环的入口结点 | 哈希map |
删除链表中重复的结点 | 用一个Head作为返回的头指针,pre作为上一个不重复的节点,last为遍历节点指针 |
二叉树的下一个结点 | 有右子树:找右子树的左孩子 无右子树:找父节点的left是node,否则node=node->next;找到根节点都找不到就返回NULL(可能是最后一个) |
对称的二叉树 | 递归思想,值也要相同 |
按之字形顺序打印二叉树 | 用一个栈的数组替换v1,v2. 这样在入栈、出栈之间,自然就满足了交换操作。 |
把二叉树打印成多行 | 层次遍历 |
序列化二叉树 | 用buf数组来存储树的结构 |
二叉搜索树的第k个结点 | 二叉搜索树按照中序遍历的顺序打印出来正好就是排序好的顺序 |
数据流中的中位数 | 最优解:用最大堆、最小堆 |
滑动窗口的最大值 |
|
矩阵中的路径 | 回溯:遍历开头结果,然后递归 |
机器人的运动范围 | 回溯:写个函数递归,注意出口,flag判断是否已经走过。 |
剪绳子 | 全部拆成2跟3,且3越多越好。注意当number=2和3也要切。 |