面试题 8. 二叉树的下一个结点 NowCoder 题目描述 给定一棵二叉树和其中的一个结点,如何找出中序遍历顺序的下一个结点?树中的结点除了有两个分别指向左右子结点的指针以外,还有一个指向父结点的指针. Java 实现 略…
题目:给定一个二叉树和其中的一个结点,请找出中序遍历顺序的下一个结点并且返回.注意,树中的结点不仅包含左右子结点,同时包含指向父结点的指针. 分析:若一个节点有右子树,那么他的下一个节点就是他右子树中的最左子节点.若没有右子树,且没有父节点,那么他的下一个节点为空.若没有右子树,且节点是父节点的左节点,那么父节点就是他的下一个节点.若没有右子树且节点不是父节点的左节点,那么沿着父节点一直向上遍历,直到其节点值的右子树不为他自己. public TreeLinkNode GetNext(TreeL…
题目:给定一棵二叉树和其中的一个节点,如何找出中序遍历序列的下一个节点?树中的节点除了有两个分别指向左.右子节点的指针,还有一个指向父节点的指针. 测试用例: 普通二叉树(完全二叉树,不完全二叉树). 特殊二叉树(所有节点都没有右子节点的二叉树:所有节点都没有左子节点的二叉树:只有一个节点的二叉树:二叉树的根节点指针为nullptr). 不同位置的节点的下一个节点(下一个节点为当前节点的右子节点.右子树的最左子节点.父节点.跨层的父节点等:当前节点没有下一个节点). 测试代码: void Tes…
题目:给定一个二叉树和其中的一个结点,请找出中序遍历顺序的下一个结点并且返回.注意,树中的结点不仅包含左右子结点,同时包含指向父结点的指针. 分析: 根据中序遍历的特点,要找到一个节点的下一个节点无非就是三种情况: 1.有右子树,这时只需要把其右孩子作为下一个遍历的(并不是要找的)节点,然后沿着该节点的左子树(如果有的话)出发,直到遇到叶子节点,那么该叶子节点就是其下一个要找的节点: 2.没有右子树,则判断该节点是否是其父节点的左孩子,如果是则其下一个要找的节点是其父节点: 3.如果不是其父节点…
题目:输入某二叉树的前序遍历和中序遍历的结果,请重新构造出该二叉树.假设输入的前序遍历和中序遍历的结果中不包含重复的数字.例如输入的前序遍历序列为{1,2,4,7,3,5,6,8}和中序遍历为{4,7,2,1,5,3,6,8},则重建出二叉树并输出它的头结点. 前序遍历:根节点-->左节点-->右节点 中序遍历:左节点-->根节点-->右节点 后序遍历:左节点-->右节点-->根节点 在二叉树的前序遍历序列中,第一个数字总是树的根节点的值.但在中序遍历中,根节点的值在序…
题目:请实现一个函数,把字符串中的每个空格替换成“%20”.例如输入“We are happy”,则输出”We%20are%20happy”. 原因:在网络编程中,如果URL参数中含有特殊字符,如:空格.“#”等,可能导致服务器端无法获得正确的参数值.我们需要将这些特殊符号转换成服务器识别的字符.转换规则是在“%”后面跟上ASCII码的两位十六进制的表示.比如:空格的ASCII码是32,即十六进制的0x20,因此空格被替换成“%20”. 时间复杂度为O(n2)不足以拿到Offer 现在我们考虑怎…
题目描述: 输入一个链表,从尾到头打印链表每个节点的值.返回新链表. import java.util.Stack; //定义链表结构 class ListNode { int value; ListNode next; } public class PrintListReverse { public static void main(String[] args) { ListNode node1 = new ListNode(); ListNode node2 = new ListNode()…
题目:把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转.输入一个递增排序的数组的一个旋转,输出旋转数组的最小元素.例如数组{3,4,5,1,2}为{1,2,3,4,5}的一个旋转,该数组的最小值为1. 解题思路: 1.暴力解法,从头到尾遍历一次,我们就能找出最小的元素,复杂度为O(n),但是没有利用输入的旋转数组的特性,肯定达不到面试官的要求. 2.二分查找,这里的数组可以看成两个有序的子数组,二分查找对有序数组非常有效,复杂度为O(logn). 具体分析: 1.先分析数组的特点…
题目:写一个函数,输入n,求斐波那契数列的第n项.斐波那契数列的定义如下: 1.效率很低效的解法,挑剔的面试官不会喜欢 使用递归实现: public class Fibonacci { public long getNum(int n){ if(n<=0){ return 0; }else if(n==1){ return 1; }else{ return getNum(n-1)+getNum(n-2); } } } 我们不难发现在这颗树中有很多的节点是重复的,而且重复的节点数会随着n的增大而急…
题目:用两个队列实现栈. 分析:通过一系列的栈的压入和弹出操作来分析用队列模拟一个栈的过程,如图所示,我们先往栈内压入一个元素a.由于两个队列现在都是空,我们可以选择把a插入两个队列中的任一个.我们不妨把a插入queue1.接下来继续往栈内压入b,c两个元素.我们把它们都插入queue1.这个时候 queue1包含3个元素a,b,c其中a位于队列的头部,c位于队列的尾部. 现在我们考虑从栈内弹出一个元素.根据栈的后进先出的原则,最后被压入栈的c应该最先被弹出.由于c位于queue1的尾部,而我们…