10 2019 档案

摘要:Given a singly linked list L: L0→L1→…→Ln-1→Ln,reorder it to: L0→Ln→L1→Ln-1→L2→Ln-2→… You may not modify the values in the list's nodes, only nodes its 阅读全文
posted @ 2019-10-31 23:58 自由之翼Az 阅读(155) 评论(0) 推荐(0) 编辑
摘要:Given a binary tree, return the preorder traversal of its nodes' values. Example: Follow up: Recursive solution is trivial, could you do it iterativel 阅读全文
posted @ 2019-10-31 23:32 自由之翼Az 阅读(166) 评论(0) 推荐(0) 编辑
摘要:Given a binary tree, return the postorder traversal of its nodes' values. Example: Follow up: Recursive solution is trivial, could you do it iterative 阅读全文
posted @ 2019-10-31 23:22 自由之翼Az 阅读(152) 评论(0) 推荐(0) 编辑
摘要:Sort a linked list using insertion sort. Sort a linked list using insertion sort. A graphical example of insertion sort. The partial sorted list (blac 阅读全文
posted @ 2019-10-30 23:29 自由之翼Az 阅读(194) 评论(0) 推荐(0) 编辑
摘要:Sort a linked list in O(n log n) time using constant space complexity. Example 1: Example 2: 阅读全文
posted @ 2019-10-30 22:05 自由之翼Az 阅读(206) 评论(0) 推荐(0) 编辑
摘要:Given n points on a 2D plane, find the maximum number of points that lie on the same straight line. Example 1: Example 2: NOTE: input types have been 阅读全文
posted @ 2019-10-29 23:17 自由之翼Az 阅读(165) 评论(0) 推荐(0) 编辑
摘要:Evaluate the value of an arithmetic expression in Reverse Polish Notation. Valid operators are +, -, *, /. Each operand may be an integer or another e 阅读全文
posted @ 2019-10-28 23:28 自由之翼Az 阅读(166) 评论(0) 推荐(0) 编辑
摘要:Given a binary tree, find its minimum depth. The minimum depth is the number of nodes along the shortest path from the root node down to the nearest l 阅读全文
posted @ 2019-10-28 23:08 自由之翼Az 阅读(154) 评论(0) 推荐(0) 编辑
摘要:题目描述 给定一个数组A[0,1,...,n-1],请构建一个数组B[0,1,...,n-1],其中B中的元素B[i]=A[0]*A[1]*...*A[i-1]*A[i+1]*...*A[n-1]。不能使用除法。 题解: 将每一行分为两半部分,0,1,2....i-1 与 i+1.....n-1这两 阅读全文
posted @ 2019-10-21 16:39 自由之翼Az 阅读(89) 评论(0) 推荐(0) 编辑
摘要:题目描述 写一个函数,求两个整数之和,要求在函数体内不得使用+、-、*、/四则运算符号。 题解: 使用位运算 1 class Solution { 2 public: 3 int Add(int num1, int num2){ 4 int sum, carry; 5 while (num2 != 阅读全文
posted @ 2019-10-20 23:01 自由之翼Az 阅读(103) 评论(0) 推荐(0) 编辑
摘要:题目描述 求1+2+3+...+n,要求不能使用乘除法、for、while、if、else、switch、case等关键字及条件判断语句(A?B:C)。 题解: 利用类的构造和析构 1 //利用类的构造 2 class Temp{ 3 public: 4 Temp() { ++N; sum += N 阅读全文
posted @ 2019-10-20 22:49 自由之翼Az 阅读(161) 评论(0) 推荐(0) 编辑
摘要:题目: 假设把某股票的价格按照时间先后顺序存储在数组中,请问买卖该股票一次可能获得的最大利润是多少?例如,一只股票在某些时间节点的价格为{9,11,8,5,7,12,16,14}。如果我们能在价格为5的时候买入并在价格为16时卖出,则能收获最大的利润11。 题解: 简单地一批 阅读全文
posted @ 2019-10-20 22:09 自由之翼Az 阅读(104) 评论(0) 推荐(0) 编辑
摘要:题目描述 每年六一儿童节,牛客都会准备一些小礼物去看望孤儿院的小朋友,今年亦是如此。HF作为牛客的资深元老,自然也准备了一些小游戏。其中,有个游戏是这样的:首先,让小朋友们围成一个大圈。然后,他随机指定一个数m,让编号为0的小朋友开始报数。每次喊到m-1的那个小朋友要出列唱首歌,然后可以在礼品箱中任 阅读全文
posted @ 2019-10-20 22:01 自由之翼Az 阅读(123) 评论(0) 推荐(0) 编辑
摘要:题目描述 LL今天心情特别好,因为他去买了一副扑克牌,发现里面居然有2个大王,2个小王(一副牌原本是54张^_^)...他随机从中抽出了5张牌,想测测自己的手气,看看能不能抽到顺子,如果抽到的话,他决定去买体育彩票,嘿嘿!!“红心A,黑桃3,小王,大王,方片5”,“Oh My God!”不是顺子.. 阅读全文
posted @ 2019-10-20 20:38 自由之翼Az 阅读(184) 评论(0) 推荐(0) 编辑
摘要:题目: 把n个骰子扔在地上,所有骰子朝上一面的点数之和为s。输入n,打印出s的所有可能的值出现的概率。 题解: 使用两个数组存每次投的点数 阅读全文
posted @ 2019-10-20 20:19 自由之翼Az 阅读(132) 评论(0) 推荐(0) 编辑
摘要:题目: 队列的最大值。请定义一个队列并实现函数max得到队列里的最大值,要求函数max、push_back和pop_front的时间复杂度都是O(1)。 题解: 使用队列,操持队列的排序为从大到小的顺序,最大值一直在队头 阅读全文
posted @ 2019-10-20 19:44 自由之翼Az 阅读(120) 评论(0) 推荐(0) 编辑
摘要:题目描述 给定一个数组和滑动窗口的大小,找出所有滑动窗口里数值的最大值。例如,如果输入数组{2,3,4,2,6,2,5,1}及滑动窗口的大小3,那么一共存在6个滑动窗口,他们的最大值分别为{4,4,6,6,6,5}; 针对数组{2,3,4,2,6,2,5,1}的滑动窗口有以下6个: {[2,3,4] 阅读全文
posted @ 2019-10-20 19:27 自由之翼Az 阅读(107) 评论(0) 推荐(0) 编辑
摘要:题目描述 汇编语言中有一种移位指令叫做循环左移(ROL),现在有个简单的任务,就是用字符串模拟这个指令的运算结果。对于一个给定的字符序列S,请你把其循环左移K位后的序列输出。例如,字符序列S=”abcXYZdef”,要求输出循环左移3位后的结果,即“XYZdefabc”。是不是很简单?OK,搞定它! 阅读全文
posted @ 2019-10-20 17:36 自由之翼Az 阅读(140) 评论(0) 推荐(0) 编辑
摘要:题目描述 牛客最近来了一个新员工Fish,每天早晨总是会拿着一本英文杂志,写些句子在本子上。同事Cat对Fish写的内容颇感兴趣,有一天他向Fish借来翻看,但却读不懂它的意思。例如,“student. a am I”。后来才意识到,这家伙原来把句子单词的顺序翻转了,正确的句子应该是“I am a 阅读全文
posted @ 2019-10-20 17:02 自由之翼Az 阅读(74) 评论(0) 推荐(0) 编辑
摘要:题目描述 小明很喜欢数学,有一天他在做数学作业时,要求计算出9~16的和,他马上就写出了正确答案是100。但是他并不满足于此,他在想究竟有多少种连续的正数序列的和为100(至少包括两个数)。没多久,他就得到另一组连续正数和为100的序列:18,19,20,21,22。现在把问题交给你,你能不能也很快 阅读全文
posted @ 2019-10-20 16:38 自由之翼Az 阅读(117) 评论(0) 推荐(0) 编辑
摘要:题目描述 输入一个递增排序的数组和一个数字S,在数组中查找两个数,使得他们的和正好是S,如果有多对数字的和等于S,输出两个数的乘积最小的。 输出描述: 对应每个测试案例,输出两个数,小的先输出。题解: 使用双指针,头和尾,和大了,右指针左移,和小了,左指针右移。 1 class Solution { 阅读全文
posted @ 2019-10-20 15:55 自由之翼Az 阅读(130) 评论(0) 推荐(0) 编辑
摘要:题目: 数组中唯一只出现一次的数字。在一个数组中除一个数字只出现一次之外,其他数字都出现了三次。请找出那个只出现一次的数字。 题解: 如果一个数字出现三次,那么它的二进制表示的每一位(0或者1)也出现三次。如果把所有出现三次的数字的二进制表示的每一位都分别加起来,那么每一位的和都能被3整除。我们把数 阅读全文
posted @ 2019-10-20 15:35 自由之翼Az 阅读(163) 评论(0) 推荐(0) 编辑
摘要:题目描述 一个整型数组里除了两个数字之外,其他的数字都出现了两次。请写程序找出这两个只出现一次的数字。 一个整型数组里除了两个数字之外,其他的数字都出现了两次。请写程序找出这两个只出现一次的数字。 题解: 我们想到异或运算的一个性质:任何一个数字异或它自己都等于0。也就是说,如果我们从头到尾依次异或 阅读全文
posted @ 2019-10-20 13:18 自由之翼Az 阅读(264) 评论(0) 推荐(0) 编辑
摘要:题目描述 输入一棵二叉树,判断该二叉树是否是平衡二叉树。 题解: 方法一:使用深度遍历,判断每个节点是不是平衡二叉树,这种从上至下的方法会导致底层的节点重复判断多次 方法二:使用后序遍历判断,这种方法为自下而上,每个节点只需要判断一次即可 1 //方法一:使用深度遍历,判断每个节点是不是平衡二叉树, 阅读全文
posted @ 2019-10-20 11:44 自由之翼Az 阅读(177) 评论(0) 推荐(0) 编辑
摘要:题目描述 输入一棵二叉树,求该树的深度。从根结点到叶结点依次经过的结点(含根、叶结点)形成树的一条路径,最长路径的长度为树的深度。 题解: 简单的深度遍历即可。 1 class Solution { 2 public: 3 int TreeDepth(TreeNode* pRoot) 4 { 5 i 阅读全文
posted @ 2019-10-20 11:13 自由之翼Az 阅读(95) 评论(0) 推荐(0) 编辑
摘要:题目描述 给定一棵二叉搜索树,请找出其中的第k小的结点。例如, (5,3,7,2,4,6,8) 中,按结点数值大小顺序第三小结点的值为4。 题解: 考察的就是中序遍历 不过注意进行剪枝 1 class Solution { 2 public: 3 TreeNode* KthNode(TreeNode 阅读全文
posted @ 2019-10-20 10:59 自由之翼Az 阅读(99) 评论(0) 推荐(0) 编辑
摘要:题目三: 数组中数值和下标相等的元素。 假设一个单调递增的数组里的每个元素都是整数并且是唯一的。请编程实现一个函数,找出数组中任意一个数值等于其下标的元素。例如,在数组{-3,-1,1,3,5}中,数字3和它的下标相等。 题解: 使用二分法,下角标小于其值,目标值在左边,下角标大于其值,目标值在右边 阅读全文
posted @ 2019-10-20 10:41 自由之翼Az 阅读(241) 评论(0) 推荐(0) 编辑
摘要:题目:0~n-1中缺失的数字。 一个长度为n-1的递增排序数组中的所有数字都是唯一的,并且每个数字都在范围0~n-1之内。 在范围0~n-1内的n个数字中有且只有一个数字不在该数组中,请找出这个数字。 题解: 使用二分法即可。 阅读全文
posted @ 2019-10-20 10:31 自由之翼Az 阅读(144) 评论(0) 推荐(0) 编辑
摘要:题目描述 统计一个数字在排序数组中出现的次数。 题解: 使用二分法找到数k然后向前找到第一个k,向后找到最后一个k,即可知道有几个k了 但一旦n个数都是k时,这个方法跟从头遍历没区别,都是O(N)的复杂度 可以再次利用二分法,在第一次找到k的左半部分使用二分法找到不再出现k的位置,其右半部份类似。 阅读全文
posted @ 2019-10-19 23:31 自由之翼Az 阅读(111) 评论(0) 推荐(0) 编辑
摘要:题目描述 输入两个链表,找出它们的第一个公共结点。 题解: 分别遍历两个链表到链尾,并计算其长度,若最后一个节点相同,则存在公共节点 然后让长链表指针从头先移动长度差个节点,然后两个链表指针一起移动,第一个出现的 相同节点就是公共节点 1 class Solution { 2 public: 3 L 阅读全文
posted @ 2019-10-19 22:36 自由之翼Az 阅读(112) 评论(0) 推荐(0) 编辑
摘要:题目描述 在数组中的两个数字,如果前面一个数字大于后面的数字,则这两个数字组成一个逆序对。输入一个数组,求出这个数组中的逆序对的总数P。并将P对1000000007取模的结果输出。 即输出P%1000000007 输入描述: 题目保证输入的数组中没有的相同的数字 数据范围: 对于%50的数据,siz 阅读全文
posted @ 2019-10-18 23:06 自由之翼Az 阅读(136) 评论(0) 推荐(0) 编辑
摘要:题目描述 请实现一个函数用来找出字符流中第一个只出现一次的字符。例如,当从字符流中只读出前两个字符"go"时,第一个只出现一次的字符是"g"。当从该字符流中读出前六个字符“google"时,第一个只出现一次的字符是"l"。 输出描述: 如果当前字符流没有存在出现一次的字符,返回#字符。题解: 使用哈 阅读全文
posted @ 2019-10-18 22:08 自由之翼Az 阅读(164) 评论(0) 推荐(0) 编辑
摘要:题目描述 在一个字符串(0<=字符串长度<=10000,全部由字母组成)中找到第一个只出现一次的字符,并返回它的位置, 如果没有则返回 -1(需要区分大小写). 题解: 想复杂了,从头遍历两轮即可。 1 class Solution { 2 public: 3 int FirstNotRepeati 阅读全文
posted @ 2019-10-18 21:48 自由之翼Az 阅读(98) 评论(0) 推荐(0) 编辑
摘要:题目描述 把只包含质因子2、3和5的数称作丑数(Ugly Number)。例如6、8都是丑数,但14不是,因为它包含质因子7。 习惯上我们把1当做是第一个丑数。求按从小到大的顺序的第N个丑数。 1 //使用遍历判断的方法 2 class Solution01 { 3 public: 4 int Ge 阅读全文
posted @ 2019-10-18 21:02 自由之翼Az 阅读(118) 评论(0) 推荐(0) 编辑
摘要:题目: 请从字符串中找出一个最长的不包含重复字符的子字符串,计算该最长子字符串的长度。假设字符串中只包含’a~z”的字符。例如,在字符串“arabcacfr"中,最长的不含重复字符的子字符串是“acfr”,长度为4。 题解: 方法一: 使用滑动窗口函数【借助string中的find函数】 方法二: 阅读全文
posted @ 2019-10-18 20:11 自由之翼Az 阅读(146) 评论(0) 推荐(0) 编辑
摘要:题目描述 在一个m*n的棋盘的每一格都放有一个礼物,每个礼物都有一定的价值(价值大于0)。你可以从棋盘的左上角开始拿格子里的礼物,并每次向左或者向下移动一格,知道到达棋盘的右下角。给定一个棋盘及其上面的礼物,请计算你最多能拿多少价值的礼物? 思路 首先这里个人认为题目中对于移动的描述有错误,应该是每 阅读全文
posted @ 2019-10-17 23:11 自由之翼Az 阅读(261) 评论(0) 推荐(0) 编辑
摘要:题目要求: 给定一个数字,按照如下规则翻译成字符串:0翻译成“a”,1翻译成“b”...25翻译成“z”。一个数字有多种翻译可能,例如12258一共有5种,分别是bccfi,bwfi,bczi,mcfi,mzi。实现一个函数,用来计算一个数字有多少种不同的翻译方法。 解题思路: 下面我们从自上而下和 阅读全文
posted @ 2019-10-17 22:23 自由之翼Az 阅读(224) 评论(0) 推荐(0) 编辑
摘要:题目描述 输入一个正整数数组,把数组里所有数字拼接起来排成一个数,打印能拼接出的所有数字中最小的一个。例如输入数组{3,32,321},则打印出这三个数字能排成的最小数字为321323。 题解: 这与PAT中最小排列组合是同理的,为了防止新组成的数字溢出,全部转化为字符串操作。 1 class So 阅读全文
posted @ 2019-10-17 21:53 自由之翼Az 阅读(113) 评论(0) 推荐(0) 编辑
摘要:题目: 数字以0123456789101112131415…的格式序列化到一个字符序列中。在这个序列中,第5位(从0开始计数)是5,第13位是1,第19位是4,等等。请写一个函数,求任意第n位对应的数字。 题解: 以第15位数字2为例(2隶属与12,两位数,位于12从左侧以0号开始下标为1的位置)步 阅读全文
posted @ 2019-10-17 21:41 自由之翼Az 阅读(169) 评论(0) 推荐(0) 编辑
摘要:题目描述 求出1~13的整数中1出现的次数,并算出100~1300的整数中1出现的次数?为此他特别数了一下1~13中包含1的数字有1、10、11、12、13因此共出现6次,但是对于后面问题他就没辙了。ACMer希望你们帮帮他,并把问题更加普遍化,可以很快的求出任意非负整数区间中1出现的次数(从1 到 阅读全文
posted @ 2019-10-17 21:02 自由之翼Az 阅读(110) 评论(0) 推荐(0) 编辑
摘要:题目描述 HZ偶尔会拿些专业问题来忽悠那些非计算机专业的同学。今天测试组开完会后,他又发话了:在古老的一维模式识别中,常常需要计算连续子向量的最大和,当向量全为正数的时候,问题很好解决。但是,如果向量中包含负数,是否应该包含某个负数,并期望旁边的正数会弥补它呢?例如:{6,-3,-2,7,-15,1 阅读全文
posted @ 2019-10-17 20:45 自由之翼Az 阅读(104) 评论(0) 推荐(0) 编辑
摘要:题目描述 如何得到一个数据流中的中位数?如果从数据流中读出奇数个数值,那么中位数就是所有数值排序之后位于中间的数值。如果从数据流中读出偶数个数值,那么中位数就是所有数值排序之后中间两个数的平均值。我们使用Insert()方法读取数据流,使用GetMedian()方法获取当前读取数据的中位数。 题解: 阅读全文
posted @ 2019-10-16 23:29 自由之翼Az 阅读(115) 评论(0) 推荐(0) 编辑
摘要:题目描述 输入n个整数,找出其中最小的K个数。例如输入4,5,1,6,2,7,3,8这8个数字,则最小的4个数字是1,2,3,4,。 题解: 原以为书中会有好方法,想不到还是排序和STL这两种方法。 1 class Solution { 2 public: 3 vector<int> GetLeas 阅读全文
posted @ 2019-10-16 23:03 自由之翼Az 阅读(173) 评论(0) 推荐(0) 编辑
摘要:题目描述 数组中有一个数字出现的次数超过数组长度的一半,请找出这个数字。例如输入一个长度为9的数组{1,2,3,2,2,2,5,4,2}。由于数字2在数组中出现了5次,超过数组长度的一半,因此输出2。如果不存在则输出0。 题解: 没什么讲的 1 class Solution { 2 public: 阅读全文
posted @ 2019-10-16 22:40 自由之翼Az 阅读(78) 评论(0) 推荐(0) 编辑
摘要:题目描述 输入一个字符串,按字典序打印出该字符串中字符的所有排列。例如输入字符串abc,则打印出由字符a,b,c所能排列出来的所有字符串abc,acb,bac,bca,cab和cba。 输入描述: 输入一个字符串,长度不超过9(可能有字符重复),字符只包括大小写字母。题解: 一种交换的递归,一种DF 阅读全文
posted @ 2019-10-16 22:01 自由之翼Az 阅读(104) 评论(0) 推荐(0) 编辑
摘要:题目描述 输入一棵二叉搜索树,将该二叉搜索树转换成一个排序的双向链表。要求不能创建任何新的结点,只能调整树中结点指针的指向。 题解: 在搜索二义树中,左子节点的值总是小于父节点的值,右子节点的值总是大于父节点的值。 因此,将二叉搜索树转换成排序双向链表时, 原先指向左子节点的指针调整为链表中指向前一 阅读全文
posted @ 2019-10-16 21:24 自由之翼Az 阅读(189) 评论(0) 推荐(0) 编辑
摘要:题目描述 输入一个复杂链表(每个节点中有节点值,以及两个指针,一个指向下一个节点,另一个特殊指针指向任意一个节点),返回结果为复制后复杂链表的head。(注意,输出结果中请不要返回参数中的节点引用,否则判题程序会直接返回空) 题解: 方法一: 使用hash表将链表节点记录,其key为节点值,这样有个 阅读全文
posted @ 2019-10-16 20:45 自由之翼Az 阅读(102) 评论(0) 推荐(0) 编辑
摘要:题目描述 输入一颗二叉树的根节点和一个整数,打印出二叉树中结点值的和为输入整数的所有路径。路径定义为从树的根结点开始往下一直到叶结点所经过的结点形成一条路径。(注意: 在返回值的list中,数组长度大的数组靠前) 题解: 一般涉及到树的题目,首先是想到DFS和BFS了 1 class Solutio 阅读全文
posted @ 2019-10-16 20:00 自由之翼Az 阅读(198) 评论(0) 推荐(0) 编辑
摘要:题目描述 输入一个整数数组,判断该数组是不是某二叉搜索树的后序遍历的结果。如果是则输出Yes,否则输出No。假设输入的数组的任意两个数字都互不相同。 题解: 这道题,一开始以为将后序遍历排序后的得到中序遍历,然后利用后序遍历和中序遍历进行二叉树的重组,但是由于后序遍历未必是BST树的,故得到的中序遍 阅读全文
posted @ 2019-10-15 23:34 自由之翼Az 阅读(153) 评论(0) 推荐(0) 编辑
摘要:题目描述 请实现一个函数按照之字形打印二叉树,即第一行按照从左到右的顺序打印,第二层按照从右至左的顺序打印,第三行按照从左到右的顺序打印,其他行以此类推。 题解: 与上道题没区别,就是在存入数据时,对于奇数行的数据,先反转一下,再存入即可 1 class Solution { 2 public: 3 阅读全文
posted @ 2019-10-15 22:53 自由之翼Az 阅读(106) 评论(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 阅读(166) 评论(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 阅读(159) 评论(0) 推荐(0) 编辑
摘要:题目描述 请实现两个函数,分别用来序列化和反序列化二叉树 二叉树的序列化是指:把一棵二叉树按照某种遍历方式的结果以某种格式保存为字符串,从而使得内存中建立起来的二叉树可以持久保存。序列化可以基于先序、中序、后序、层序的二叉树遍历方式来进行修改,序列化的结果是一个字符串,序列化时通过 某种符号表示空节 阅读全文
posted @ 2019-10-15 22:04 自由之翼Az 阅读(113) 评论(0) 推荐(0) 编辑
摘要:题目描述 输入两个整数序列,第一个序列表示栈的压入顺序,请判断第二个序列是否可能为该栈的弹出顺序。假设压入栈的所有数字均不相等。例如序列1,2,3,4,5是某栈的压入顺序,序列4,5,3,2,1是该压栈序列对应的一个弹出序列,但4,3,5,1,2就不可能是该压栈序列的弹出序列。(注意:这两个序列的长 阅读全文
posted @ 2019-10-14 22:06 自由之翼Az 阅读(150) 评论(0) 推荐(0) 编辑
摘要:题目描述 定义栈的数据结构,请在该类型中实现一个能够得到栈中所含最小元素的min函数(时间复杂度应为O(1))。 题解: 借助辅助栈,新的数据<=f辅助栈顶时,就压入辅助栈,这样,就能保证辅助找栈顶永远是最小数。 1 class Solution { 2 public: 3 void push(in 阅读全文
posted @ 2019-10-14 21:50 自由之翼Az 阅读(95) 评论(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 阅读(162) 评论(0) 推荐(0) 编辑
摘要:题目描述 请实现一个函数,用来判断一颗二叉树是不是对称的。注意,如果一个二叉树同此二叉树的镜像是同样的,定义其为对称的。 题解: 使用正常前序遍历与反向的前序遍历进行比较结果即可,注意,需将空节点放入比较。 方法一为使用额外空间进行存储比较,方法二为直接递归比较。 1 class Solution0 阅读全文
posted @ 2019-10-14 21:15 自由之翼Az 阅读(91) 评论(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 阅读(107) 评论(0) 推荐(0) 编辑
摘要:题目描述 输入两棵二叉树A,B,判断B是不是A的子结构。(ps:我们约定空树不是任意一个树的子结构) 题解: 注意,所谓的子结构,是树的形状和值相同,并非判断B是不是A的一部分【如果是这样,那就是直接比较地址了】 使用递归; 1 class Solution { 2 public: 3 bool H 阅读全文
posted @ 2019-10-14 20:16 自由之翼Az 阅读(118) 评论(0) 推荐(0) 编辑
摘要:题目描述 输入两个单调递增的链表,输出两个链表合成后的链表,当然我们需要合成后的链表满足单调不减规则。 题解: 使用普通方法,或者递归,注意新的头节点即可。 1 //使用普通的合并方法 2 class Solution01 { 3 public: 4 ListNode* Merge(ListNode 阅读全文
posted @ 2019-10-14 19:40 自由之翼Az 阅读(106) 评论(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 阅读(104) 评论(0) 推荐(0) 编辑
摘要:题目描述 给一个链表,若其中包含环,请找出该链表的环的入口结点,否则,输出null。 题解: 使用快慢指针即可,若快慢指针会相遇,则有环,否则快指针先到空节点; 此时,快指针从此处一次移一步遍历,慢指针从头结点开始遍历,两指针再次相遇时即为环的重合节点; 1 class Solution { 2 p 阅读全文
posted @ 2019-10-13 22:52 自由之翼Az 阅读(110) 评论(0) 推荐(0) 编辑
摘要:题目描述 输入一个链表,输出该链表中倒数第k个结点。 题解: 1、普通解法,先遍历一遍计算链表长度,然后遍历到倒数第k个节点; 2、只遍历一遍,使用双指针,使得头尾指针位差为k,那么当尾指针为空时,头指针就是倒数第k个位置。 1 //遍历两次,垃圾 2 class Solution01 { 3 pu 阅读全文
posted @ 2019-10-13 22:26 自由之翼Az 阅读(153) 评论(0) 推荐(0) 编辑
摘要:题目描述 输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有的奇数位于数组的前半部分,所有的偶数位于数组的后半部分,并保证奇数和奇数,偶数和偶数之间的相对位置不变。 题解: 一种是数字的相对位置不变,即1,2,3,4 -》 1,3,2,4 这样只能使用额外空间了,牛客题解就是这个 1 阅读全文
posted @ 2019-10-13 21:30 自由之翼Az 阅读(120) 评论(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 阅读(130) 评论(0) 推荐(0) 编辑
摘要:题目描述 请实现一个函数用来匹配包括'.'和'*'的正则表达式。模式中的字符'.'表示任意一个字符,而'*'表示它前面的字符可以出现任意次(包含0次)。 在本题中,匹配是指字符串的所有字符匹配整个模式。例如,字符串"aaa"与模式"a.a"和"ab*ac*a"匹配,但是与"aa.a"和"ab*a"均 阅读全文
posted @ 2019-10-11 23:17 自由之翼Az 阅读(148) 评论(0) 推荐(0) 编辑
摘要:题目描述 在一个排序的链表中,存在重复的结点,请删除该链表中重复的结点,重复的结点不保留,返回链表头指针。 例如,链表1->2->3->3->4->4->5 处理后为 1->2->5 题解: 这道题没什么讲的,注意指向空的边界就行,新建一个头节点更容易处理。 1 class Solution { 2 阅读全文
posted @ 2019-10-11 22:39 自由之翼Az 阅读(114) 评论(0) 推荐(0) 编辑
摘要:题目一: 在O(1)时间内删除链表节点。给定单向链表的头指针和一个节点指针,定义一个函数在O(1)时间内删除该节点。 书本讲得不明就里 阅读全文
posted @ 2019-10-11 22:10 自由之翼Az 阅读(117) 评论(0) 推荐(0) 编辑
摘要:题目: 输入数字n,按顺序打印出从1到最大的n位十进制数。比如输入3,则打印出1、2、3一直到最大的3位数999。 题解: 注意大数溢出问题,故使用字符串更靠谱 阅读全文
posted @ 2019-10-11 21:48 自由之翼Az 阅读(108) 评论(0) 推荐(0) 编辑
摘要:题目描述 给定一个double类型的浮点数base和int类型的整数exponent。求base的exponent次方。 保证base和exponent不同时为0 一般解法: 直接相乘; 1 class Solution01 { 2 public: 3 double Power(double bas 阅读全文
posted @ 2019-10-11 21:02 自由之翼Az 阅读(262) 评论(0) 推荐(0) 编辑
摘要:题目描述 输入一个整数,输出该数二进制表示中1的个数。其中负数用补码表示。 有可能引起死循环解法: 每次判断最右端是不是1【与 & 1即可】,是就cnt++,然后右移一位,直到num为0,结束; 但是这只对正数有用,而负数右移是左端补充1,这样导致num最终成为 0xFFFFFFFF,从而右移成了死 阅读全文
posted @ 2019-10-11 20:19 自由之翼Az 阅读(213) 评论(0) 推荐(0) 编辑
摘要:题目描述 给你一根长度为n的绳子,请把绳子剪成m段(m、n都是整数,n>1并且m>1),每段绳子的长度记为k[0],k[1],...,k[m]。请问k[0]xk[1]x...xk[m]可能的最大乘积是多少?例如,当绳子的长度是8时,我们把它剪成长度分别为2、3、3的三段,此时得到的最大乘积是18。 阅读全文
posted @ 2019-10-11 19:45 自由之翼Az 阅读(172) 评论(0) 推荐(0) 编辑
摘要:题目描述 地上有一个m行和n列的方格。一个机器人从坐标0,0的格子开始移动,每一次只能向左,右,上,下四个方向移动一格,但是不能进入行坐标和列坐标的数位之和大于k的格子。 例如,当k为18时,机器人能够进入方格(35,37),因为3+5+3+7 = 18。但是,它不能进入方格(35,38),因为3+ 阅读全文
posted @ 2019-10-11 16:34 自由之翼Az 阅读(172) 评论(0) 推荐(0) 编辑
摘要:题目描述 请设计一个函数,用来判断在一个矩阵中是否存在一条包含某字符串所有字符的路径。路径可以从矩阵中的任意一个格子开始,每一步可以在矩阵中向左,向右,向上,向下移动一个格子。如果一条路径经过了矩阵中的某一个格子,则该路径不能再进入该格子。 例如 a b c e s f c s a d e e 矩阵 阅读全文
posted @ 2019-10-11 16:04 自由之翼Az 阅读(145) 评论(0) 推荐(0) 编辑
摘要:题目描述 我们可以用2*1的小矩形横着或者竖着去覆盖更大的矩形。请问用n个2*1的小矩形无重叠地覆盖一个2*n的大矩形,总共有多少种方法? 题解: 使用递归或者动态规划,明显,递归没有动态规划优 1 class Solution01 { 2 public: 3 int rectCover(int n 阅读全文
posted @ 2019-10-11 14:48 自由之翼Az 阅读(118) 评论(0) 推荐(0) 编辑
摘要:题目描述 一只青蛙一次可以跳上1级台阶,也可以跳上2级……它也可以跳上n级。求该青蛙跳上一个n级的台阶总共有多少种跳法。 题解: 纯找规律题: 1 class Solution { 2 public: 3 int jumpFloorII(int number) { 4 if (number < 0) 阅读全文
posted @ 2019-10-11 14:38 自由之翼Az 阅读(99) 评论(0) 推荐(0) 编辑
摘要:题目描述 把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转。输入一个非递减排序的数组的一个旋转,输出旋转数组的最小元素。例如数组{3,4,5,1,2}为{1,2,3,4,5}的一个旋转,该数组的最小值为1。NOTE:给出的所有元素都大于0,若数组大小为0,请返回0。 把一个数组最开始 阅读全文
posted @ 2019-10-11 13:05 自由之翼Az 阅读(166) 评论(0) 推荐(0) 编辑
摘要:题目描述 一只青蛙一次可以跳上1级台阶,也可以跳上2级。求该青蛙跳上一个n级的台阶总共有多少种跳法(先后次序不同算不同的结果)。 题解: 说俗一点,就是找规律; 不不,首先,我们分析一下,青蛙第一次可以跳一步,则其跳剩下的n-1个台阶的方法数为:f(n-1); 也可以跳两步,则其跳剩下n-2个台阶的 阅读全文
posted @ 2019-10-11 10:36 自由之翼Az 阅读(111) 评论(0) 推荐(0) 编辑
摘要:题目描述 大家都知道斐波那契数列,现在要求输入一个整数n,请你输出斐波那契数列的第n项(从0开始,第0项为0)。 n<=39 有多种方法,简单的循环、递归、动态规划; 1 class Solution01 { 2 public: 3 int Fibonacci(int n) { 4 int a = 阅读全文
posted @ 2019-10-11 10:20 自由之翼Az 阅读(131) 评论(0) 推荐(0) 编辑
摘要:题目描述 用两个栈来实现一个队列,完成队列的Push和Pop操作。 队列中的元素为int类型。 题解: 有两个栈,stack1和stack2 push只在stack1上操作,pop只在stack2上操作 当stack2不为空时,直接从stack2栈顶弹出 当stack2为空时,将stack1的数据全 阅读全文
posted @ 2019-10-11 09:43 自由之翼Az 阅读(98) 评论(0) 推荐(0) 编辑
摘要:题目描述 给定一个二叉树和其中的一个结点,请找出中序遍历顺序的下一个结点并且返回。注意,树中的结点不仅包含左右子结点,同时包含指向父结点的指针。 题目的意思是,在一颗二叉树的中序遍历中,给出其中一个节点,让你找到中序中该节点的下一个节点 题解: 情况 1:某节点有右子树,下一节点为右子树中的最左子节 阅读全文
posted @ 2019-10-10 23:20 自由之翼Az 阅读(100) 评论(0) 推荐(0) 编辑
摘要:题目描述 输入某二叉树的前序遍历和中序遍历的结果,请重建出该二叉树。假设输入的前序遍历和中序遍历的结果中都不含重复的数字。例如输入前序遍历序列{1,2,4,7,3,5,6,8}和中序遍历序列{4,7,2,1,5,3,8,6},则重建二叉树并返回。 已知中序遍历和前序遍历,可以得到唯一的二叉树 1 c 阅读全文
posted @ 2019-10-10 22:49 自由之翼Az 阅读(120) 评论(0) 推荐(0) 编辑
摘要:题目描述 输入一个链表,按链表从尾到头的顺序返回一个ArrayList。 有多种方法。 1 class Solution { 2 public: 3 vector<int> printListFromTailToHead(ListNode* head) { 4 ListNode *p = head; 阅读全文
posted @ 2019-10-10 22:22 自由之翼Az 阅读(125) 评论(0) 推荐(0) 编辑
摘要:题目描述 请实现一个函数,将一个字符串中的每个空格替换成“%20”。例如,当字符串为We Are Happy.则经过替换之后的字符串为We%20Are%20Happy。 注意事项: 《剑指offer》上的length为str的最大长度空间 而牛客上的lenght为str的长度,包括了'\0' 由于s 阅读全文
posted @ 2019-10-10 21:37 自由之翼Az 阅读(123) 评论(0) 推荐(0) 编辑
摘要:题目描述 在一个长度为n的数组里的所有数字都在0到n-1的范围内。 数组中某些数字是重复的,但不知道有几个数字是重复的。也不知道每个数字重复几次。请找出数组中任意一个重复的数字。 例如,如果输入长度为7的数组{2,3,1,0,2,5,3},那么对应的输出是第一个重复的数字2。 方法一: 从0位置遍历 阅读全文
posted @ 2019-10-10 20:39 自由之翼Az 阅读(115) 评论(0) 推荐(0) 编辑
摘要:题目描述 在一个二维数组中(每个一维数组的长度相同),每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序。请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数。 注意: 数组不一定是这样的: 1 2 3 4 5 6 7 8 9 而是这样的: 1 2 8 9 阅读全文
posted @ 2019-10-10 19:02 自由之翼Az 阅读(169) 评论(0) 推荐(0) 编辑

点击右上角即可分享
微信分享提示