摘要: 题目描述 输入一个复杂链表(每个节点中有节点值,以及两个指针,一个指向下一个节点,另一个特殊指针指向任意一个节点),返回结果为复制后复杂链表的head。(注意,输出结果中请不要返回参数中的节点引用,否则判题程序会直接返回空) 思路:N'连接在N的后面,可以以O(n)的时间复制特殊指针的指向,再将两个 阅读全文
posted @ 2017-12-25 11:58 jeysin 阅读(106) 评论(0) 推荐(0) 编辑
摘要: 题目描述 输入一颗二叉树和一个整数,打印出二叉树中结点值的和为输入整数的所有路径。路径定义为从树的根结点开始往下一直到叶结点所经过的结点形成一条路径 思路:回溯法 1 class Solution { 2 public: 3 void DFS(TreeNode *root, vector<vecto 阅读全文
posted @ 2017-12-25 10:46 jeysin 阅读(147) 评论(0) 推荐(0) 编辑
摘要: 题目描述 输入一个整数数组,判断该数组是不是某二叉搜索树的后序遍历的结果。如果是则输出Yes,否则输出No。假设输入的数组的任意两个数字都互不相同。 思路:序列的最后一个节点是根节点,找分界点,分为左右子树,递归。 1 class Solution { 2 public: 3 int getMid( 阅读全文
posted @ 2017-12-25 10:26 jeysin 阅读(134) 评论(0) 推荐(0) 编辑
摘要: 题目描述 从上往下打印出二叉树的每个节点,同层节点从左至右打印 思路:广度优先遍历 1 class Solution { 2 public: 3 vector<int> PrintFromTopToBottom(TreeNode* root) { 4 vector<int> res; 5 if(ro 阅读全文
posted @ 2017-12-25 10:00 jeysin 阅读(146) 评论(0) 推荐(0) 编辑
摘要: 题目描述 输入两个整数序列,第一个序列表示栈的压入顺序,请判断第二个序列是否为该栈的弹出顺序。假设压入栈的所有数字均不相等。例如序列1,2,3,4,5是某栈的压入顺序,序列4,5,3,2,1是该压栈序列对应的一个弹出序列,但4,3,5,1,2就不可能是该压栈序列的弹出序列。(注意:这两个序列的长度是 阅读全文
posted @ 2017-12-25 09:53 jeysin 阅读(89) 评论(0) 推荐(0) 编辑