剑指offer
Anpedestrian
这个作者很懒,什么都没留下…
展开
-
剑指offer--二叉树的下一结点(中序遍历思想,枚举各种情况)
题目描述给定一个二叉树和其中的一个结点,请找出中序遍历顺序的下一个结点并且返回。注意,树中的结点不仅包含左右子结点,同时包含指向父结点的指针。解题思路:一种最朴素的方法:由于TreeLinkNode中包含有next指针,指向当前结点的父节点,这样可以找到整棵二叉树的根节点。题目要求中序遍历的下一个节点,可以预处理获取整棵树的中序遍历序列,保存在一个容器中,之后for循环遍历容器中的节点,当访问到当前节点与给定节点相同时,直接return容器中的下一个节点即可。这种方法没有写。以上是机试的思路原创 2020-10-02 15:22:50 · 131 阅读 · 0 评论 -
剑指offer--序列化与反序列化二叉树(先序递归,建树)
题目描述请实现两个函数,分别用来序列化和反序列化二叉树二叉树的序列化是指:把一棵二叉树按照某种遍历方式的结果以某种格式保存为字符串,从而使得内存中建立起来的二叉树可以持久保存。序列化可以基于先序、中序、后序、层序的二叉树遍历方式来进行修改,序列化的结果是一个字符串,序列化时通过 某种符号表示空节点(#),以 ! 表示一个结点值的结束(value!)。二叉树的反序列化是指:根据某种遍历顺序得到的序列化字符串结果str,重构二叉树。例如,我们可以把一个只有根节点为1的二叉树序列化为"1,..原创 2020-09-30 22:25:51 · 129 阅读 · 0 评论 -
剑指offer--数据流中的中位数(大小根堆优先队列)
题目描述如何得到一个数据流中的中位数?如果从数据流中读出奇数个数值,那么中位数就是所有数值排序之后位于中间的数值。如果从数据流中读出偶数个数值,那么中位数就是所有数值排序之后中间两个数的平均值。我们使用Insert()方法读取数据流,使用GetMedian()方法获取当前读取数据的中位数。解题思路:最朴素的想法是,通过设定一个ArrayList链表,在插入函数中,每次通过add函数添加num到当前状态下的链表中。在GetMedian函数中,由于数据是随着数据流不断更新的,所以需要先使用.原创 2020-09-30 11:30:27 · 133 阅读 · 0 评论 -
剑指offer--剪绳子(记忆化递归 || dp || 数学)
题目描述给你一根长度为n的绳子,请把绳子剪成整数长的m段(m、n都是整数,n>1并且m>1,m<=n),每段绳子的长度记为k[1],...,k[m]。请问k[1]x...xk[m]可能的最大乘积是多少?例如,当绳子的长度是8时,我们把它剪成长度分别为2、3、3的三段,此时得到的最大乘积是18。输入描述:输入一个数n,意义见题面。(2 <= n <= 60)输出描述:输出答案。示例1输入8输出18解题思路:给出几种方法,看到原创 2020-09-29 16:36:43 · 131 阅读 · 0 评论 -
剑指offer--链表中环的入口结点
题目描述给一个链表,若其中包含环,请找出该链表的环的入口结点,否则,输出null。解题思路:两种方法,HashSet结构和双指针做法。HashSet方法:直接遍历链表,每次指向当前节点的下一个节点。如果当前节点不在set集合中,执行进集合操作。如果当前节点在set集合中,那么直接返回当前节点即为所求的环的入口节点。控制边界,如果链表为空,直接返回为null。代码如下:/* public class ListNode { int val; ListNode nex.原创 2020-09-29 11:21:27 · 141 阅读 · 0 评论 -
剑指offer--树的子结构(节点遍历)
题目描述输入两棵二叉树A,B,判断B是不是A的子结构。(ps:我们约定空树不是任意一个树的子结构)解题思路:递归解决问题的过程:1.递归解决什么问题,判断是否B树是A树的子结构。相同,返回true;不同返回false。2.递归的终止条件,如果当前递归中,树B为空,返回true,与树A无关;如果树B不为空,但是树A为空,那么直接返回false,回溯证明当前递归的过程并不是我们所需要的。3.下一次递归的参数:如果A的根节点和B的根节点不相等,直接返回false。证明当前路径不匹配,直接回原创 2020-09-26 19:53:31 · 170 阅读 · 0 评论 -
剑指offer--平衡二叉树(二叉树深度+递归)
题目描述输入一棵二叉树,判断该二叉树是否是平衡二叉树。在这里,我们只需要考虑其平衡性,不需要考虑其是不是排序二叉树解题思路:根据求解二叉树深度的问题。可以将该问题从两种解题方法考虑,分别是自顶向下和自底向上。首先,自顶向下的方法中,通过引入一个HashMap的结构,记录节点与节点深度。不过java中的hashmap使用get函数之前需要使用containsKey函数判断是否包含当前节点。先通过dfs函数,递归求解二叉树中全部节点及其对应的深度,并使用hashmap数据结构保存下.原创 2020-09-25 15:05:04 · 109 阅读 · 0 评论 -
剑指offer--不用加减乘除做加法(位运算)
题目描述写一个函数,求两个整数之和,要求在函数体内不得使用+、-、*、/四则运算符号。解题思路:不可以使用加减运算符,那么就要想到使用位运算解决加法操作。分为两个步骤,一个是无进位相加结果,另一个是进位相加的二进制结果,类似于整数相加结果的余数,但是应该向左位移一位,因为进位只对前面的位数有影响。对于负数而言,引入了反码和补码的概念,减去一个数,相当于加上一个数的负数,因为计算机中只提供了加法的运算,代码如下:public class Solution { public int原创 2020-09-24 16:35:43 · 90 阅读 · 0 评论 -
剑指offer--旋转数组的最小数字(二分)
题目描述把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转。输入一个非递减排序的数组的一个旋转,输出旋转数组的最小元素。例如数组[3,4,5,1,2]为[1,2,3,4,5]的一个旋转,该数组的最小值为1。NOTE:给出的所有元素都大于0,若数组大小为0,请返回0。解题思路:这道题由于设定了旋转数组,直接遍历就没什么意思了。使用的二分查找的方法,但是array[mid]的比较数值target设定为多少是需要考究的,一般不给出target值的二分直接将边界值设定为targ.原创 2020-09-23 22:43:10 · 83 阅读 · 0 评论 -
剑指offer--二叉搜索树与二叉链表(线索化二叉树思想,链表)
题目描述输入一棵二叉搜索树,将该二叉搜索树转换成一个排序的双向链表。要求不能创建任何新的结点,只能调整树中结点指针的指向。解题思想:最朴素的解题思想是:对于二叉搜索树而言,中序遍历的结果就是一个递增的序列。为了将搜索树转换成一个排序的双向链表,又不可以创建新的节点,可以使用ArrayList列表加入到搜索树的中序遍历中去,当访问到当前节点时,将节点添加到ArrayList链表中,最后一层for循环统一对链表中节点间的左右指针进行更新。使用的是其他方法,这段代码直接粘上了,仅供参考:p.原创 2020-09-23 16:02:27 · 141 阅读 · 0 评论 -
剑指offer--二进制中1的个数(位运算)
题目描述输入一个整数,输出该数32位二进制表示中1的个数。其中负数用补码表示。解题思路:四种方法。第一种对于负数是不可行的,其他三种可行。第一种方法是模拟二进制的移位,每次循环将整数对2取余,如果不为0,代表最后一位为1,则ans++,否则最后一位为0,直接将整数除以2,类似于二进制移位操作。但是这种方法有一个弊端,就是对于int类型所能取到的最小负数,即-Integer.MAX_VALUE,没办法正确处理。解释如下,因为int型的最小负数,换成二进制是10000....(31个0),.原创 2020-09-23 09:57:32 · 100 阅读 · 0 评论