![](https://img-blog.csdnimg.cn/20201014180756930.png?x-oss-process=image/resize,m_fixed,h_64,w_64)
剑指 Offer
jhh_seven
念念不忘,必有回响!
展开
-
剑指 Offer 62. 圆圈中最后剩下的数字
剑指 Offer 62. 圆圈中最后剩下的数字原创 2021-04-06 09:58:11 · 48 阅读 · 0 评论 -
剑指 Offer 31. 栈的压入、弹出序列
剑指 Offer 31. 栈的压入、弹出序列输入两个整数序列,第一个序列表示栈的压入顺序,请判断第二个序列是否为该栈的弹出顺序。假设压入栈的所有数字均不相等。例如,序列 {1,2,3,4,5} 是某栈的压栈序列,序列 {4,5,3,2,1} 是该压栈序列对应的一个弹出序列,但 {4,3,5,1,2} 就不可能是该压栈序列的弹出序列。注意:判断压栈出栈的顺序是否一致,即判断入栈时元素和出栈元素的peek()是否一致,不一致时继续入栈,一致时出栈,最后盘算stack是否为空即可。 public原创 2021-01-13 01:44:09 · 60 阅读 · 0 评论 -
面试题58 - II. 左旋转字符串(切片 / 列表 / 字符串,清晰图解)
面试题58 - II. 左旋转字符串(切片 / 列表 / 字符串,清晰图解)字符串的左旋转操作是把字符串前面的若干个字符转移到字符串的尾部。请定义一个函数实现字符串左旋转操作的功能。比如,输入字符串"abcdefg"和数字2,该函数将返回左旋转两位得到的结果"cdefgab"。public class ReverseLeftWords { public String reverseLeftWords(String s, int n) { return s.substring(原创 2020-12-03 13:13:49 · 136 阅读 · 0 评论 -
剑指 Offer 57 - II. 和为s的连续正数序列
剑指 Offer 57 - II. 和为s的连续正数序列输入一个正整数 target ,输出所有和为 target 的连续正整数序列(至少含有两个数)。序列内的数字由小到大排列,不同序列按照首个数字从小到大排列。 public int[][] findContinuousSequence(int target) { int i = 1; int j = 1; int sum = 0; List<int[]> res原创 2020-12-03 12:26:45 · 65 阅读 · 0 评论 -
剑指 Offer 58 - I. 翻转单词顺序
剑指 Offer 58 - I. 翻转单词顺序输入一个英文句子,翻转句子中单词的顺序,但单词内字符的顺序不变。为简单起见,标点符号和普通字母一样处理。例如输入字符串"I am a student. “,则输出"student. a am I”。 public String reverseWords(String s) { s = s.trim(); // 删除首尾空格 int j = s.length() - 1, i = j; StringBu原创 2020-12-02 22:02:03 · 54 阅读 · 0 评论 -
剑指 Offer 55 - II. 平衡二叉树
剑指 Offer 55 - II. 平衡二叉树输入一棵二叉树的根节点,判断该树是不是平衡二叉树。如果某二叉树中任意节点的左右子树的深度相差不超过1,那么它就是一棵平衡二叉树。后序遍历即最后遍历根节点,剪枝即从低部开始若底部子树不是平衡二叉树则返回-1,即最后遍历根节点。 public boolean isBalanced(TreeNode root) { return maxDepth(root) != -1; } int maxDepth(TreeNode原创 2020-11-19 16:33:21 · 198 阅读 · 0 评论 -
剑指 Offer 55 - I. 二叉树的深度
剑指 Offer 55 - I. 二叉树的深度输入一棵二叉树的根节点,求该树的深度。从根节点到叶节点依次经过的节点(含根、叶节点)形成树的一条路径,最长路径的长度为树的深度。方法一:递归(深度优先遍历——先序遍历、中序遍历、后序遍历) public int maxDepth(TreeNode root) { if( root == null) return 0; int left = maxDepth(root.left); int righ原创 2020-11-19 11:47:14 · 62 阅读 · 0 评论 -
剑指 Offer 54. 二叉搜索树的第k大节点
剑指 Offer 54. 二叉搜索树的第k大节点给定一棵二叉搜索树,请找出其中第k大的节点。知识点补充:二叉搜索树即二叉排序树,是指左子树俊小于根节点,右子树均大于根节点,遍历顺序 中序遍历(左根右)升序所以右根左就是降序,第几大就是第几个数字 class TreeNode{ int val; TreeNode left; TreeNode right; TreeNode(int x){ val =原创 2020-11-19 10:54:39 · 52 阅读 · 0 评论 -
剑指 Offer 53 - II. 0~n-1中缺失的数字
剑指 Offer 53 - II. 0~n-1中缺失的数字一个长度为n-1的递增排序数组中的所有数字都是唯一的,并且每个数字都在范围0~n-1之内。在范围0~n-1内的n个数字中有且只有一个数字不在该数组中,请找出这个数字。...原创 2020-11-18 23:51:19 · 50 阅读 · 0 评论 -
剑指 Offer 53 - I. 在排序数组中查找数字 I
剑指 Offer 53 - I. 在排序数组中查找数字 I统计一个数字在排序数组中出现的次数。 public int search(int[] nums, int target){ //定义左右边界 int i = 0, j = nums.length - 1; while (i <= j){ int m = (i+j)/2; //目标值大于中间值,则搜索右半边 if(n原创 2020-11-17 14:21:04 · 116 阅读 · 0 评论 -
剑指 Offer 52. 两个链表的第一个公共节点
剑指 Offer 52. 两个链表的第一个公共节点输入两个链表,找出它们的第一个公共节点。如下面的两个链表:public class GetIntersectionNode { public class ListNode{ int val; ListNode next; ListNode(int x){ val = x; next = null; } } publ原创 2020-11-17 10:38:00 · 51 阅读 · 0 评论 -
剑指 Offer 50. 第一个只出现一次的字符
剑指 Offer 50. 第一个只出现一次的字符在字符串 s 中找出第一个只出现一次的字符。如果没有,返回一个单空格。 s 只包含小写字母。 public char firstUniqChar(String s) { HashMap<Character, Boolean> hashMap = new HashMap<>(); char[] arry = s.toCharArray(); for (int i = 0; i原创 2020-11-16 15:38:40 · 73 阅读 · 0 评论 -
剑指 Offer 42. 连续子数组的最大和
剑指 Offer 42. 连续子数组的最大和输入一个整型数组,数组中的一个或连续多个整数组成一个子数组。求所有子数组的和的最大值。要求时间复杂度为O(n)。public class MaxSubArray { public int maxSubArray(int[] nums) { int res = nums[0]; for (int i = 1;i < nums.length;i++){ nums[i] += Math.max原创 2020-11-16 11:16:57 · 49 阅读 · 0 评论 -
剑指 Offer 40. 最小的k个数
剑指 Offer 40. 最小的k个数输入整数数组 arr ,找出其中最小的 k 个数。例如,输入4、5、1、6、2、7、3、8这8个数字,则最小的4个数字是1、2、3、4。方法一:直接排序 public static int[] getLeastNumbers(int[] arr, int k) { Arrays.sort(arr); int[] result = new int[k]; for(int i = 0; i < k; i++原创 2020-10-20 22:36:57 · 50 阅读 · 0 评论 -
剑指 Offer 39. 数组中出现次数超过一半的数字(三种方法)
剑指 Offer 39. 数组中出现次数超过一半的数字数组中有一个数字出现的次数超过数组长度的一半,请找出这个数字。你可以假设数组是非空的,并且给定的数组总是存在多数元素。原创 2020-10-20 10:34:57 · 156 阅读 · 0 评论 -
剑指 Offer 32 - III. 从上到下打印二叉树 III
剑指 Offer 32 - III. 从上到下打印二叉树 III请实现一个函数按照之字形顺序打印二叉树,即第一行按照从左到右的顺序打印,第二层按照从右到左的顺序打印,第三行再按照从左到右的顺序打印,其他行以此类推。...原创 2020-09-28 17:46:50 · 71 阅读 · 0 评论 -
剑指 Offer 32 - II. 从上到下打印二叉树 II
剑指 Offer 32 - II. 从上到下打印二叉树 II从上到下按层打印二叉树,同一层的节点按从左到右的顺序打印,每一层打印到一行例如: 给定二叉树: [3,9,20,null,null,15,7], public List<List<Integer>> levelOrder(TreeNode root) { Queue<TreeNode> queue = new LinkedList<>(); queue.原创 2020-09-28 11:32:12 · 142 阅读 · 0 评论 -
剑指 Offer 32 - I. 从上到下打印二叉树
剑指 Offer 32 - I. 从上到下打印二叉树从上到下打印出二叉树的每个节点,同一层的节点按照从左到右的顺序打印。解题思路:题目要求的二叉树的 从上至下 打印(即按层打印),又称为二叉树的 广度优先搜索(BFS)。BFS 通常借助 队列 的先入先出特性来实现。 public int[] levelOrder(TreeNode root) { //层次遍历,当队列不为空输出 Queue<TreeNode> queue = new LinkedLis原创 2020-09-28 00:13:14 · 111 阅读 · 2 评论 -
剑指 Offer 28. 对称的二叉树
剑指 Offer 28. 对称的二叉树请实现一个函数,用来判断一棵二叉树是不是对称的。如果一棵二叉树和它的镜像一样,那么它是对称的。方法一:队列public boolean isSymmetric(TreeNode root) { //队列 Queue<TreeNode> queue = new LinkedList<>(); if (root == null) return true; //左子节点和右子节点同时入队原创 2020-09-27 23:27:41 · 81 阅读 · 0 评论 -
剑指 Offer 27. 二叉树的镜像
剑指 Offer 27. 二叉树的镜像请完成一个函数,输入一个二叉树,该函数输出它的镜像。 public TreeNode mirrorTree(TreeNode root) { if (root == null) return null; TreeNode temp = root.left; root.left = mirrorTree(root.right); root.right = mirrorTree(temp);原创 2020-09-27 22:23:24 · 47 阅读 · 0 评论 -
剑指 Offer 25. 合并两个排序的链表
剑指 Offer 25. 合并两个排序的链表输入两个递增排序的链表,合并这两个链表并使新链表中的节点仍然是递增排序的。注意不可以将dumy设置为nullpublic class MergeTwoLists { public static class ListNode { int val; ListNode next; public ListNode(int x) { val = x; } }原创 2020-09-27 20:56:00 · 49 阅读 · 0 评论 -
剑指 Offer 24. 反转链表+ 最强图解,臭不要脸
剑指 Offer 24. 反转链表定义一个函数,输入一个链表的头节点,反转该链表并输出反转后链表的头节点。方法一:使用栈解决链表的反转是老生常谈的一个问题了,同时也是面试中常考的一道题。最简单的一种方式就是使用栈,因为栈是先进后出的。实现原理就是把链表节点一个个入栈,当全部入栈完之后再一个个出栈,出栈的时候在把出栈的结点串成一个新的链表。 public static ListNode reverseListTwo(ListNode head){ //先将结点存入栈中原创 2020-09-25 21:17:01 · 283 阅读 · 0 评论 -
剑指 Offer 22. 链表中倒数第k个节点
剑指 Offer 22. 链表中倒数第k个节点输入一个链表,输出该链表中倒数第k个节点。为了符合大多数人的习惯,本题从1开始计数,即链表的尾节点是倒数第1个节点。例如,一个链表有6个节点,从头节点开始,它们的值依次是1、2、3、4、5、6。这个链表的倒数第3个节点是值为4的节点。方法一:单指针1.dummy赋值为头指针,计算链表长度count2.指针head = head.next执行count-k-1次,则指针就移动到了倒数第k节点3.返回这个节点的指针即可public class GetK原创 2020-09-25 00:27:33 · 94 阅读 · 0 评论 -
剑指 Offer 21. 调整数组顺序使奇数位于偶数前面
剑指 Offer 21. 调整数组顺序使奇数位于偶数前面输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有奇数位于数组的前半部分,所有偶数位于数组的后半部分。x&1 位运算 等价于 x % 2 取余运算,即皆可用于判断数字奇偶性x&1 = 1 x奇数x&1 = 0 x偶数方法一:申请一个数组 // 新建一个数组,偶数从后面开始插入,奇数从前面开始插入 public static int[] exchange(int[] nums) {原创 2020-09-24 23:06:30 · 148 阅读 · 3 评论 -
剑指 Offer 18. 删除链表的节点
剑指 Offer 18. 删除链表的节点给定单向链表的头指针和一个要删除的节点的值,定义一个函数删除该节点。返回删除后的链表的头节点。方法一:单指针附上完整的代码,需要注意的地方都在代码里标注清楚了,本方法使用的是查找到被删除节点的上一节点,所以只需要额外申请一个ListNode即可public class DeleteNode { static class ListNode{ int val; ListNode next; ListNode(原创 2020-09-24 11:50:31 · 88 阅读 · 0 评论 -
剑指 Offer 15. 二进制中1的个数!你不明白的都在这里?吐血整理
剑指 Offer 15. 二进制中1的个数请实现一个函数,输入一个整数,输出该数二进制表示中 1 的个数。例如,把 9 表示成二进制是 1001,有 2 位是 1。因此,如果输入 9,则该函数输出 2。博主刚开始看到这个题时以为传进去的n是十进制所以整道题需要以下三步1.十进制转换为二进制,存取余的值2.倒序输出存的取余结果3.与1比较现在想想其实不用倒序,因为不管是正序还是倒序1的个数是确定的,因为思考到十进制转二进制需要除二取余然后倒序排列,所以博主想到了栈这个数据结构,先push进去余数原创 2020-09-23 19:45:59 · 348 阅读 · 3 评论 -
剑指 Offer 11. 旋转数组的最小数字
剑指 Offer 11. 旋转数组的最小数字把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转。输入一个递增排序的数组的一个旋转,输出旋转数组的最小元素。例如,数组 [3,4,5,1,2] 为 [1,2,3,4,5] 的一个旋转,该数组的最小值为1。方法一:暴力法 public static int minArray(int[] numbers){ //循环比较数组元素, 找到变小元素的下标即可 int index = 0; /**原创 2020-09-22 23:55:24 · 154 阅读 · 0 评论 -
剑指 Offer 10- II. 青蛙跳台阶问题
剑指 Offer 10- II. 青蛙跳台阶问题一只青蛙一次可以跳上1级台阶,也可以跳上2级台阶。求该青蛙跳上一个 n 级的台阶总共有多少种跳法。答案需要取模 1e9+7(1000000007),如计算初始结果为:1000000008,请返回 1。同斐波那契数列,注意初始值的不同!方法一:递归,超时 public static int numWays(int n){ if(n < 1) return 1; if(n < 3) return n;原创 2020-09-22 20:32:10 · 1550 阅读 · 2 评论 -
剑指 Offer 10- I. 斐波那契数列
剑指 Offer 10- I. 斐波那契数列写一个函数,输入 n ,求斐波那契(Fibonacci)数列的第 n 项。斐波那契数列的定义如下:第一种方式:递归,超时public class Fib { public static int fib(int n) { //递归调用 int value = 0; if(n == 0) { return 0; } else if(n == 1) {原创 2020-09-22 17:48:17 · 109 阅读 · 1 评论 -
剑指 Offer 09. 用两个栈实现队列
剑指 Offer 09. 用两个栈实现队列用两个栈实现一个队列。队列的声明如下,请实现它的两个函数 appendTail 和 deleteHead ,分别完成在队列尾部插入整数和在队列头部删除整数的功能。(若队列中没有元素,deleteHead 操作返回 -1 )很多人看不懂题目,博主刚开始也是萌萌,简单明了,带你直接看懂题目和例子。 输入: [“CQueue”,“appendTail”,“deleteHead”,“deleteHead”] 这里是要执行的方法,从左到右执行[[],[3],[],[]原创 2020-09-22 16:16:08 · 121 阅读 · 0 评论 -
剑指 Offer 07. 重建二叉树
剑指 Offer 07. 重建二叉树输入某二叉树的前序遍历和中序遍历的结果,请重建该二叉树。假设输入的前序遍历和中序遍历的结果中都不含重复的数字原创 2020-09-22 01:00:07 · 125 阅读 · 5 评论 -
剑指 Offer 06. 从尾到头打印链表
剑指 Offer 06. 从尾到头打印链表输入一个链表的头节点,从尾到头反过来返回每个节点的值(用数组返回)。第一种方法:存入可变数组中,倒序插入数组 public static int[] reversePrint(ListNode head) { //将数据放入arrlist中 ArrayList<Integer> value = new ArrayList<>(); while (head != null){原创 2020-09-21 14:25:22 · 93 阅读 · 1 评论 -
剑指 Offer 05. 替换空格五种方式
剑指 Offer 05. 替换空格请实现一个函数,把字符串 s 中的每个空格替换成"%20"。方法一:使用StingBuffer public static String replaceSpace(String s) { //new StringBulider(速度快,线程不安全)或者StringBuffer填充 StringBuilder sb = new StringBuilder(); char[] arry = s.toCharArray原创 2020-09-20 16:36:40 · 238 阅读 · 0 评论 -
剑指 Offer 04. 二维数组中的查找
剑指 Offer 04. 二维数组中的查找在一个 n * m 的二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序。请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数。方法一:常规解法:遍历数组比较是否有相同的数字 public boolean findNumberIn2DArrayTwo(int[][] matrix, int target) { for(int i=0;i<matrix.length;i ++)原创 2020-09-17 23:55:02 · 74 阅读 · 1 评论 -
剑指 Offer 03. 数组中重复的数字
找出数组中重复的数字。在一个长度为 n 的数组 nums 里的所有数字都在 0~n-1 的范围内。数组中某些数字是重复的,但不知道有几个数字重复了,也不知道每个数字重复了几次。请找出数组中任意一个重复的数字。class Solution { public int findRepeatNumber(int[] nums) { List<Integer> repeat = new ArrayList<>(); int i,j;原创 2020-09-17 17:53:33 · 82 阅读 · 0 评论