- 博客(28)
- 资源 (10)
- 收藏
- 关注
原创 剑指offer:058 对称的二叉树 附:java实现
题目描述 对称的二叉树 请实现一个函数,用来判断一颗二叉树是不是对称的。注意,如果一个二叉树同此二叉树的镜像是同样的,定义其为对称的。 思路 我们对树进行 递归遍历,如果不对称则判false; java实现: public class Solution { boolean isSymmetrical(TreeNode pRoot) { if(pRoot...
2020-03-14 07:49:43 115
原创 剑指offer:057 二叉树的下一个结点 附:java实现
题目描述 给定一个二叉树和其中的一个结点,请找出中序遍历顺序的下一个结点并且返回。注意,树中的结点不仅包含左右子结点,同时包含指向父结点的指针。 思路: 1、有右子树的,那么下个结点就是右子树最左边的点;(eg:D,B,E,A,C,G) 2、没有右子树的,也可以分成两类, a)是父节点左孩子(eg:N,I,L) ,那么父节点就是下一个节点 ; b)是父节点的右孩子(eg:H,J,K,...
2020-03-14 07:43:30 88
原创 剑指offer:056 删除链表中重复的结点 附:java实现
题目描述 删除链表中重复的结点 在一个排序的链表中,存在重复的结点,请删除该链表中重复的结点,重复的结点不保留,返回链表头指针。 例如,链表1->2->3->3->4->4->5 处理后为 1->2->5 思路 非递归的代码: 1. 首先添加一个头节点,以方便碰到第一个,第二个节点就相同的情况 2.设置 pre ,last 指针, pre...
2020-03-13 08:32:15 107
原创 剑指offer:055 链表中环的入口节点 附:java实现
题目描述 给一个链表,若其中包含环,请找出该链表的环的入口结点,否则,输出null。 思路: 设置快慢指针,都从链表头出发,快指针每次走两步,慢指针一次走一步,假如有环,一定相遇于环中某点(结论1)。接着让两个指针分别从相遇点和链表头出发,两者都改为每次走一步,最终相遇于环入口(结论2)。以下是两个结论证明: 两个结论: 1、设置快慢指针,假如有环,他们最后一定相遇。 2、两个指针...
2020-03-13 08:26:19 116
原创 剑指offer:054 字符流中第一个不重复的字符 附:java实现
题目描述 请实现一个函数用来找出字符流中第一个只出现一次的字符。例如,当从字符流中只读出前两个字符"go"时,第一个只出现一次的字符是"g"。当从该字符流中读出前六个字符“google"时,第一个只出现一次的字符是"l"。 输出描述: 如果当前字符流没有存在出现一次的字符,返回#字符 思路 依旧用Map 来计算字符重复的次数。返回只出现一次的字符。 用list来保证顺序。 java实...
2020-03-12 08:57:02 84
原创 剑指offer:053 表示数值的字符串 附:java实现
题目描述 表示数值的字符串 请实现一个函数用来判断字符串是否表示数值(包括整数和小数)。例如,字符串"+100","5e2","-123","3.1416"和"-1E-16"都表示数值。 但是"12e","1a3.14","1.2.3","+-5"和"12e+4.3"都不是。 思路 12e说明e的后面必须有数字,不能有两个e +-5说明符号位要么出现一次在首位,要么出现一次在e的后一位...
2020-03-12 08:54:42 122
原创 剑指offer:052 正则表达式匹配 附:java实现
题目描述 请实现一个函数用来匹配包括'.'和'*'的正则表达式。模式中的字符'.'表示任意一个字符,而'*'表示它前面的字符可以出现任意次(包含0次)。 在本题中,匹配是指字符串的所有字符匹配整个模式。例如,字符串"aaa"与模式"a.a"和"ab*ac*a"匹配,但是与"aa.a"和"ab*a"均不匹配 思路 当模式中的第二个字符不是“*”时: 1、如果字符串第一个字符和模式中的第一个字...
2020-03-11 08:22:14 71
原创 剑指offer:051 构建乘积数组 附:java实现
题目描述 给定一个数组A[0,1,...,n-1],请构建一个数组B[0,1,...,n-1],其中B中的元素B[i]=A[0]*A[1]*...*A[i-1]*A[i+1]*...*A[n-1]。不能使用除法。(注意:规定B[0] = A[1] * A[2] * ... * A[n-1],B[n-1] = A[0] * A[1] * ... * A[n-2];) 思路: B[i]的值可以看...
2020-03-11 08:18:45 104
原创 剑指offer:050 数组中重复的数字 附:java实现
题目描述 数组中重复的数字 在一个长度为n的数组里的所有数字都在0到n-1的范围内。 数组中某些数字是重复的,但不知道有几个数字是重复的。也不知道每个数字重复几次。请找出数组中任意一个重复的数字。 例如,如果输入长度为7的数组{2,3,1,0,2,5,3},那么对应的输出是第一个重复的数字2。 思路: 我们可以用一个数组来模拟。 hash[ array[i] ]++ ; 如果数字重复了...
2020-03-10 08:50:36 74
原创 剑指offer:049 字符串转换成整数 附:java实现
题目描述 将一个字符串转换成一个整数,要求不能使用字符串转换整数的库函数。 数值为0或者字符串不是一个合法的数值则返回0 输入描述: 输入一个字符串,包括数字字母符号,可以为空 输出描述: 如果是合法的数值表达则返回该数字,否则返回0 示例1 输入 +2147483647 1a33 输出 2147483647 0 思路: 此题的关键就在于 如何处理 ...
2020-03-10 08:46:42 83
原创 剑指offer:048 不用加减乘除做加法 附:java实现
题目描述 写一个函数,求两个整数之和,要求在函数体内不得使用+、-、*、/四则运算符号。 思路: 用异或 相加,与运算计算进位 java实现: /** 两个数异或:相当于每一位相加,而不考虑进位; 两个数相与,并左移一位:相当于求得进位; 将上述两步的结果相加 **/ public class Solution { public int Add(int nu...
2020-03-09 09:43:05 82
原创 剑指offer:047 求1+2+3+...+n附:java实现
题目描述 求1+2+3+...+n,要求不能使用乘除法、for、while、if、else、switch、case等关键字及条件判断语句(A?B:C)。 思路: 直接递归实现即可 java实现 public class Solution { public int Sum_Solution(int n) { /** * 解题思路: 1.需利用逻辑与的短路特性实现递...
2020-03-09 09:40:20 67
原创 剑指offer:046 孩子们的游戏 附:java实现
题目描述 每年六一儿童节,牛客都会准备一些小礼物去看望孤儿院的小朋友,今年亦是如此。HF作为牛客的资深元老,自然也准备了一些小游戏。其中,有个游戏是这样的:首先,让小朋友们围成一个大圈。然后,他随机指定一个数m,让编号为0的小朋友开始报数。每次喊到m-1的那个小朋友要出列唱首歌,然后可以在礼品箱中任意的挑选礼物,并且不再回到圈中,从他的下一个小朋友开始,继续0...m-1报数....这样下去.....
2020-03-08 08:40:35 126
原创 剑指offer:045 扑克牌顺子 附:java实现
题目描述 扑克牌顺子 LL今天心情特别好,因为他去买了一副扑克牌,发现里面居然有2个大王,2个小王(一副牌原本是54张^_^)...他随机从中抽出了5张牌,想测测自己的手气,看看能不能抽到顺子,如果抽到的话,他决定去买体育彩票,嘿嘿!!“红心A,黑桃3,小王,大王,方片5”,“Oh My God!”不是顺子.....LL不高兴了,他想了想,决定大\小 王可以看成任何数字,并且A看作1,J为11...
2020-03-08 08:33:37 98
原创 剑指offer:044 翻转单词顺序列 附:java实现
题目描述 翻转单词顺序列 牛客最近来了一个新员工Fish,每天早晨总是会拿着一本英文杂志,写些句子在本子上。同事Cat对Fish写的内容颇感兴趣,有一天他向Fish借来翻看,但却读不懂它的意思。例如,“student. a am I”。后来才意识到,这家伙原来把句子单词的顺序翻转了,正确的句子应该是“I am a student.”。Cat对一一的翻转这些单词顺序可不在行,你能帮助他么? 思...
2020-03-07 09:48:52 100
原创 剑指offer:043 左旋转字符串 附:java实现
题目描述 汇编语言中有一种移位指令叫做循环左移(ROL),现在有个简单的任务,就是用字符串模拟这个指令的运算结果。对于一个给定的字符序列S,请你把其循环左移K位后的序列输出。例如,字符序列S=”abcXYZdef”,要求输出循环左移3位后的结果,即“XYZdefabc”。是不是很简单?OK,搞定它! 思路: 我们可以新建一个 StringBuilder 来保存我们需要旋转的字符 例如 ab...
2020-03-07 09:40:31 164
原创 剑指offer:042 和为s的两个数字 附:java实现
题目描述 输入一个递增排序的数组和一个数字S,在数组中查找两个数,使得他们的和正好是S,如果有多对数字的和等于S,输出两个数的乘积最小的。 输出描述: 对应每个测试案例,输出两个数,小的先输出。 思路: 为了保证乘机最小 所有我们需要从两侧 开始计算。 1.如果和小于 Sum 则 左边的右移 2.如果和大于 Sum 则 右边的左移 最终 第一个等于Sum的 也保证了...
2020-03-06 08:16:33 97
原创 剑指offer:041 和为s的连续正数序列 附:java实现
题目描述 小明很喜欢数学,有一天他在做数学作业时,要求计算出9~16的和,他马上就写出了正确答案是100。但是他并不满足于此,他在想究竟有多少种连续的正数序列的和为100(至少包括两个数)。没多久,他就得到另一组连续正数和为100的序列:18,19,20,21,22。现在把问题交给你,你能不能也很快的找出所有和为S的连续正数序列? Good Luck! 输出描述: 输出所有和为S的连续正数...
2020-03-06 08:08:33 70
原创 剑指offer:040 数组中只出现一次的数字 附:java实现
题目描述 一个整型数组里除了两个数字之外,其他的数字都出现了两次。请写程序找出这两个只出现一次的数字。 思路: 如果只有两个数字只出现了一次。其他出现两次 我们可以利用 异或 的特点; 例如 则 5 是 101 2是 010 2^5 转为2进制 就是 0 1 1 1 我们可以以 他们异或的结果 来 把他们分开。比如这个 我们就可以把 第一位是否是1 (从异或的结果是...
2020-03-05 10:17:13 161
原创 剑指offer:039 平衡二叉树 附:java实现
题目描述 输入一棵二叉树,判断该二叉树是否是平衡二叉树。 思路: 递归遍历左右子树,如果平衡则继续递归,如果不平衡就直接返回-1 java实现: public class Solution { public boolean IsBalanced_Solution(TreeNode root) { return getDepth(root) != -1; ...
2020-03-05 09:57:33 71
原创 剑指offer:038 二叉树的深度 附:java实现
题目描述 输入一棵二叉树,求该树的深度。从根结点到叶结点依次经过的结点(含根、叶结点)形成树的一条路径,最长路径的长度为树的深度。 思路: 递归遍历左右子树,每次+1 即可 java实现: import java.lang.Math; public class Solution { public int TreeDepth(TreeNode pRoot) { ...
2020-03-04 09:06:43 80
原创 037 数字在排序数组中出现的次数附:java实现
题目描述 数字在排序数组中出现的次数 统计一个数字在排序数组中出现的次数。 思路: 例如 1222 2345 K=2 我么需要找到第一个2 和 最后一个2的位置 然后就可以统计次数了 java实现: public class Solution { public int GetNumberOfK(int [] array , int k) { int...
2020-03-04 09:04:31 194
原创 剑指offer:036 两个链表的公共节点 附:java实现
题目描述 输入两个链表,找出它们的第一个公共结点。(注意因为传入数据是链表,所以错误测试数据的提示是用其他方式显示的,保证传入数据是正确的) 思路: 可以利用HashMap 的containsKey 实现 相同的比较 java实现: import java.util.HashMap; public class Solution { public ListNode FindF...
2020-03-03 10:12:31 90
原创 剑指offer:035 数组中的逆序对 附:java实现
题目描述 数组中的逆序对 在数组中的两个数字,如果前面一个数字大于后面的数字,则这两个数字组成一个逆序对。输入一个数组,求出这个数组中的逆序对的总数P。并将P对1000000007取模的结果输出。 即输出P%1000000007 思路: 归并排序 中的比较大小操作 恰好 可以 用于我们的题目; 例如 如果8 大于 6 则 8肯定大于123 如果7 大于6 7肯定大于 123...
2020-03-03 10:06:01 138
原创 剑指offer:034 第一个只出现一次的字符 附:java实现
题目描述 在一个字符串(0<=字符串长度<=10000,全部由字母组成)中找到第一个只出现一次的字符,并返回它的位置, 如果没有则返回 -1(需要区分大小写) 思路: 此处我们需要用LinkedHashMap 来保证字符的输入顺序 然后利用HashMap的特性来,找到只出现一次 并且 第一个 出现的字符 java实现: import java.util.LinkedHa...
2020-03-02 10:21:52 111
原创 剑指offer:033 丑数 附:java实现
题目描述 丑数 把只包含质因子2、3和5的数称作丑数(Ugly Number)。例如6、8都是丑数,但14不是,因为它包含质因子7。 习惯上我们把1当做是第一个丑数。求按从小到大的顺序的第N个丑数。 思路: 其实就是p = 2 ^ x * 3 ^ y * 5 ^ z java实现: import java.util.ArrayList; public class Solution {...
2020-03-02 10:18:19 81
原创 剑指offer:032 把数组排成最小的数 附:java实现
题目描述 把数组排成最小的数 输入一个正整数数组,把数组里所有数字拼接起来排成一个数,打印能拼接出的所有数字中最小的一个。例如输入数组{3,32,321},则打印出这三个数字能排成的最小数字为321323。 思路: 我们可以定义一个比较器,规则设置成拼接最小数字即可。 例如 3 和 32 因为332 比 323 大 则 顺序 改变为 32 ,3 java实现: imp...
2020-03-01 10:05:18 87
原创 剑指offer:031 整数中1出现的次数 附:java实现
题目描述 求出1~13的整数中1出现的次数,并算出100~1300的整数中1出现的次数?为此他特别数了一下1~13中包含1的数字有1、10、11、12、13因此共出现6次,但是对于后面问题他就没辙了。ACMer希望你们帮帮他,并把问题更加普遍化,可以很快的求出任意非负整数区间中1出现的次数(从1 到 n 中1出现的次数)。 思路: 我们考虑按位计算1的个数 比如 123 公式:on...
2020-03-01 09:45:12 65
DynamicThreadPool.zip
2020-09-02
空空如也
TA创建的收藏夹 TA关注的收藏夹
TA关注的人