随笔分类 -  剑指offer

摘要:题目描述 输入一个整数数组,判断该数组是不是某二叉搜索树的后序遍历的结果。如果是则输出Yes,否则输出No。假设输入的数组的任意两个数字都互不相同。 题解: 这道题,一开始以为将后序遍历排序后的得到中序遍历,然后利用后序遍历和中序遍历进行二叉树的重组,但是由于后序遍历未必是BST树的,故得到的中序遍 阅读全文
posted @ 2019-10-15 23:34 自由之翼Az 阅读(157) 评论(0) 推荐(0)
摘要:题目描述 请实现一个函数按照之字形打印二叉树,即第一行按照从左到右的顺序打印,第二层按照从右至左的顺序打印,第三行按照从左到右的顺序打印,其他行以此类推。 题解: 与上道题没区别,就是在存入数据时,对于奇数行的数据,先反转一下,再存入即可 1 class Solution { 2 public: 3 阅读全文
posted @ 2019-10-15 22:53 自由之翼Az 阅读(111) 评论(0) 推荐(0)
摘要:题目描述 从上到下按层打印二叉树,同一层结点从左至右输出。每一层输出一行。 题解: 使用BFS,按层打印即可 1 class Solution { 2 public: 3 vector<vector<int> > Print(TreeNode* pRoot) { 4 vector<vector<in 阅读全文
posted @ 2019-10-15 22:46 自由之翼Az 阅读(168) 评论(0) 推荐(0)
摘要:题目描述 从上往下打印出二叉树的每个节点,同层节点从左至右打印。 题解: 就是简单的层序遍历 1 class Solution { 2 public: 3 vector<int> PrintFromTopToBottom(TreeNode* root) { 4 vector<int>res; 5 B 阅读全文
posted @ 2019-10-15 22:27 自由之翼Az 阅读(163) 评论(0) 推荐(0)
摘要:题目描述 请实现两个函数,分别用来序列化和反序列化二叉树 二叉树的序列化是指:把一棵二叉树按照某种遍历方式的结果以某种格式保存为字符串,从而使得内存中建立起来的二叉树可以持久保存。序列化可以基于先序、中序、后序、层序的二叉树遍历方式来进行修改,序列化的结果是一个字符串,序列化时通过 某种符号表示空节 阅读全文
posted @ 2019-10-15 22:04 自由之翼Az 阅读(116) 评论(0) 推荐(0)
摘要:题目描述 输入两个整数序列,第一个序列表示栈的压入顺序,请判断第二个序列是否可能为该栈的弹出顺序。假设压入栈的所有数字均不相等。例如序列1,2,3,4,5是某栈的压入顺序,序列4,5,3,2,1是该压栈序列对应的一个弹出序列,但4,3,5,1,2就不可能是该压栈序列的弹出序列。(注意:这两个序列的长 阅读全文
posted @ 2019-10-14 22:06 自由之翼Az 阅读(155) 评论(0) 推荐(0)
摘要:题目描述 定义栈的数据结构,请在该类型中实现一个能够得到栈中所含最小元素的min函数(时间复杂度应为O(1))。 题解: 借助辅助栈,新的数据<=f辅助栈顶时,就压入辅助栈,这样,就能保证辅助找栈顶永远是最小数。 1 class Solution { 2 public: 3 void push(in 阅读全文
posted @ 2019-10-14 21:50 自由之翼Az 阅读(97) 评论(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 阅读(168) 评论(0) 推荐(0)
摘要:题目描述 请实现一个函数,用来判断一颗二叉树是不是对称的。注意,如果一个二叉树同此二叉树的镜像是同样的,定义其为对称的。 题解: 使用正常前序遍历与反向的前序遍历进行比较结果即可,注意,需将空节点放入比较。 方法一为使用额外空间进行存储比较,方法二为直接递归比较。 1 class Solution0 阅读全文
posted @ 2019-10-14 21:15 自由之翼Az 阅读(93) 评论(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 阅读(111) 评论(0) 推荐(0)
摘要:题目描述 输入两棵二叉树A,B,判断B是不是A的子结构。(ps:我们约定空树不是任意一个树的子结构) 题解: 注意,所谓的子结构,是树的形状和值相同,并非判断B是不是A的一部分【如果是这样,那就是直接比较地址了】 使用递归; 1 class Solution { 2 public: 3 bool H 阅读全文
posted @ 2019-10-14 20:16 自由之翼Az 阅读(123) 评论(0) 推荐(0)
摘要:题目描述 输入两个单调递增的链表,输出两个链表合成后的链表,当然我们需要合成后的链表满足单调不减规则。 题解: 使用普通方法,或者递归,注意新的头节点即可。 1 //使用普通的合并方法 2 class Solution01 { 3 public: 4 ListNode* Merge(ListNode 阅读全文
posted @ 2019-10-14 19:40 自由之翼Az 阅读(110) 评论(0) 推荐(0)
摘要:题目描述 输入一个链表,反转链表后,输出新链表的表头。 题解: 每次只反转一个节点,先记住cur->next, 然后pre->cur,即可; 1 class Solution { 2 public: 3 ListNode* ReverseList(ListNode* pHead) { 4 if (p 阅读全文
posted @ 2019-10-13 23:20 自由之翼Az 阅读(106) 评论(0) 推荐(0)
摘要:题目描述 给一个链表,若其中包含环,请找出该链表的环的入口结点,否则,输出null。 题解: 使用快慢指针即可,若快慢指针会相遇,则有环,否则快指针先到空节点; 此时,快指针从此处一次移一步遍历,慢指针从头结点开始遍历,两指针再次相遇时即为环的重合节点; 1 class Solution { 2 p 阅读全文
posted @ 2019-10-13 22:52 自由之翼Az 阅读(115) 评论(0) 推荐(0)
摘要:题目描述 输入一个链表,输出该链表中倒数第k个结点。 题解: 1、普通解法,先遍历一遍计算链表长度,然后遍历到倒数第k个节点; 2、只遍历一遍,使用双指针,使得头尾指针位差为k,那么当尾指针为空时,头指针就是倒数第k个位置。 1 //遍历两次,垃圾 2 class Solution01 { 3 pu 阅读全文
posted @ 2019-10-13 22:26 自由之翼Az 阅读(156) 评论(0) 推荐(0)
摘要:题目描述 输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有的奇数位于数组的前半部分,所有的偶数位于数组的后半部分,并保证奇数和奇数,偶数和偶数之间的相对位置不变。 题解: 一种是数字的相对位置不变,即1,2,3,4 -》 1,3,2,4 这样只能使用额外空间了,牛客题解就是这个 1 阅读全文
posted @ 2019-10-13 21:30 自由之翼Az 阅读(124) 评论(0) 推荐(0)
摘要:题目描述 请实现一个函数用来判断字符串是否表示数值(包括整数和小数)。例如,字符串"+100","5e2","-123","3.1416"和"-1E-16"都表示数值。 但是"12e","1a3.14","1.2.3","+-5"和"12e+4.3"都不是。 题解: 表示数值的字符串遵循模式A[[B 阅读全文
posted @ 2019-10-13 20:29 自由之翼Az 阅读(133) 评论(0) 推荐(0)
摘要:题目描述 请实现一个函数用来匹配包括'.'和'*'的正则表达式。模式中的字符'.'表示任意一个字符,而'*'表示它前面的字符可以出现任意次(包含0次)。 在本题中,匹配是指字符串的所有字符匹配整个模式。例如,字符串"aaa"与模式"a.a"和"ab*ac*a"匹配,但是与"aa.a"和"ab*a"均 阅读全文
posted @ 2019-10-11 23:17 自由之翼Az 阅读(153) 评论(0) 推荐(0)
摘要:题目描述 在一个排序的链表中,存在重复的结点,请删除该链表中重复的结点,重复的结点不保留,返回链表头指针。 例如,链表1->2->3->3->4->4->5 处理后为 1->2->5 题解: 这道题没什么讲的,注意指向空的边界就行,新建一个头节点更容易处理。 1 class Solution { 2 阅读全文
posted @ 2019-10-11 22:39 自由之翼Az 阅读(117) 评论(0) 推荐(0)
摘要:题目一: 在O(1)时间内删除链表节点。给定单向链表的头指针和一个节点指针,定义一个函数在O(1)时间内删除该节点。 书本讲得不明就里 阅读全文
posted @ 2019-10-11 22:10 自由之翼Az 阅读(121) 评论(0) 推荐(0)