摘要: 题目描述 输入两个整数序列,第一个序列表示栈的压入顺序,请判断第二个序列是否可能为该栈的弹出顺序。假设压入栈的所有数字均不相等。例如序列1,2,3,4,5是某栈的压入顺序,序列4,5,3,2,1是该压栈序列对应的一个弹出序列,但4,3,5,1,2就不可能是该压栈序列的弹出序列。(注意:这两个序列的长 阅读全文
posted @ 2019-10-14 22:06 自由之翼Az 阅读(146) 评论(0) 推荐(0) 编辑
摘要: 题目描述 定义栈的数据结构,请在该类型中实现一个能够得到栈中所含最小元素的min函数(时间复杂度应为O(1))。 题解: 借助辅助栈,新的数据<=f辅助栈顶时,就压入辅助栈,这样,就能保证辅助找栈顶永远是最小数。 1 class Solution { 2 public: 3 void push(in 阅读全文
posted @ 2019-10-14 21:50 自由之翼Az 阅读(93) 评论(0) 推荐(0) 编辑
摘要: 题目描述 输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字,例如,如果输入如下4 X 4矩阵: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 则依次打印出数字1,2,3,4,8,12,16,15,14,13,9,5,6,7,11,10. 题解: 初始化一个 阅读全文
posted @ 2019-10-14 21:35 自由之翼Az 阅读(158) 评论(0) 推荐(0) 编辑
摘要: 题目描述 请实现一个函数,用来判断一颗二叉树是不是对称的。注意,如果一个二叉树同此二叉树的镜像是同样的,定义其为对称的。 题解: 使用正常前序遍历与反向的前序遍历进行比较结果即可,注意,需将空节点放入比较。 方法一为使用额外空间进行存储比较,方法二为直接递归比较。 1 class Solution0 阅读全文
posted @ 2019-10-14 21:15 自由之翼Az 阅读(90) 评论(0) 推荐(0) 编辑
摘要: 题目描述 操作给定的二叉树,将其变换为源二叉树的镜像。 输入描述: 二叉树的镜像定义:源二叉树 8 / \ 6 10 / \ / \ 5 7 9 11 镜像二叉树 8 / \ 10 6 / \ / \ 11 9 7 5题解: 直接用递归: 1 class Solution { 2 public: 3 阅读全文
posted @ 2019-10-14 20:36 自由之翼Az 阅读(105) 评论(0) 推荐(0) 编辑
摘要: 题目描述 输入两棵二叉树A,B,判断B是不是A的子结构。(ps:我们约定空树不是任意一个树的子结构) 题解: 注意,所谓的子结构,是树的形状和值相同,并非判断B是不是A的一部分【如果是这样,那就是直接比较地址了】 使用递归; 1 class Solution { 2 public: 3 bool H 阅读全文
posted @ 2019-10-14 20:16 自由之翼Az 阅读(114) 评论(0) 推荐(0) 编辑
摘要: 题目描述 输入两个单调递增的链表,输出两个链表合成后的链表,当然我们需要合成后的链表满足单调不减规则。 题解: 使用普通方法,或者递归,注意新的头节点即可。 1 //使用普通的合并方法 2 class Solution01 { 3 public: 4 ListNode* Merge(ListNode 阅读全文
posted @ 2019-10-14 19:40 自由之翼Az 阅读(103) 评论(0) 推荐(0) 编辑