剑指offer
文章平均质量分 60
m0_37965348
这个作者很懒,什么都没留下…
展开
-
数组中重复的数字
题目描述在一个长度为n的数组里的所有数字都在0到n-1的范围内。 数组中某些数字是重复的,但不知道有几个数字是重复的。也不知道每个数字重复几次。请找出数组中任意一个重复的数字。 例如,如果输入长度为7的数组{2,3,1,0,2,5,3},那么对应的输出是第一个重复的数字2。思路这道题当然可以用map。但是由于题目中数字范围的要求,所以 出现了在数组自身上的hash实现。空间复杂度O(n)map...转载 2018-04-09 17:19:28 · 76 阅读 · 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]。不能使用除法。class Solution {public: vector<int> multiply(const vector<int>& A) { ...转载 2018-04-09 21:35:58 · 102 阅读 · 0 评论 -
复杂链表的复制
题目描述输入一个复杂链表(每个节点中有节点值,以及两个指针,一个指向下一个节点,另一个特殊指针指向任意一个节点),返回结果为复制后复杂链表的head。(注意,输出结果中请不要返回参数中的节点引用,否则判题程序会直接返回空)思路 方法一: 1. 完全复制链表,仅生成next骨干部分; 2. 生成每个结点的random指针; 3. 生成每个指针时,以label为键值,在新链中查找。原创 2018-04-02 17:05:48 · 93 阅读 · 0 评论 -
字符流中第一个不重复的数字
题目描述请实现一个函数用来找出字符流中第一个只出现一次的字符。例如,当从字符流中只读出前两个字符"go"时,第一个只出现一次的字符是"g"。当从该字符流中读出前六个字符“google"时,第一个只出现一次的字符是"l"。输出描述:如果当前字符流没有存在出现一次的字符,返回#字符。提供一个高效的算法:思路:时间复杂度O(1),空间复杂度O(n) 1、用一个128大小的数组统计每个字符出...转载 2018-04-09 23:32:46 · 148 阅读 · 0 评论 -
链表中环的入口结点
题目描述一个链表中包含环,请找出该链表的环的入口结点。思路方法一:这道题思路真是太巧妙了。假设x为环前面的路程(黑色路程),a为环入口到相遇点的路程(蓝色路程,假设顺时针走), c为环的长度(蓝色+橙色路程) 当快慢指针相遇的时候: 此时慢指针走的路程为Sslow = x + m * c + a 快指针走的路程为Sfast = x + n * c + a 2 Sslow = Sfast...转载 2018-04-10 23:38:03 · 165 阅读 · 0 评论 -
二叉搜索树与双向链表
题目描述输入一棵二叉搜索树,将该二叉搜索树转换成一个排序的双向链表。要求不能创建任何新的结点,只能调整树中结点指针的指向。思路递归方法:将左子树构造成双链表,并返回链表尾节点。如果左子树链表不为空的话,将当前root追加到左子树链表。将右子树构造成双链表,并返回链表尾节点。定位至右子树双链表的第一个节点。如果右子树链表不为空的话,将该链表追加到root节点之后。根据...原创 2018-04-03 17:53:55 · 92 阅读 · 0 评论 -
删除链表中重复的结点
题目描述在一个排序的链表中,存在重复的结点,请删除该链表中重复的结点,重复的结点不保留,返回链表头指针。 例如,链表1->2->3->3->4->4->5 处理后为 1->2->5分析除了一般情况以外,还会出现: 链表前几个元素相同 链表后几个元素相同代码我的代码class Solution {public: L...原创 2018-04-11 11:55:58 · 113 阅读 · 0 评论 -
字符串的排列
题目描述输入一个字符串,按字典序打印出该字符串中字符的所有排列。例如输入字符串abc,则打印出由字符a,b,c所能排列出来的所有字符串abc,acb,bac,bca,cab和cba。思路本题解空间就是一棵排列树,按照一定条件生成排列树。 并将其每一条路径压入vector中。代码class Solution { vector<string> ver;p...原创 2018-04-04 10:21:32 · 75 阅读 · 0 评论 -
链表中倒数第K个节点
题目描述输入一个链表,输出该链表中倒数第k个结点。思路两个指针,第一个指针先走k-1步,第二个指针开始走。复杂度O(n)./*struct ListNode { int val; struct ListNode *next; ListNode(int x) : val(x), next(NULL) { }};*/class Solution {public: List...原创 2018-03-29 10:09:48 · 75 阅读 · 0 评论 -
反转链表——reverse link
题目描述输入一个链表,反转链表后,输出链表的所有元素。思路利用STL之stack stack的成员函数示例 size()返回栈的元素数O(1)top()返回栈顶的元素O(1)pop()删除元素,无返回值O(1)push(x)...原创 2018-03-29 10:32:30 · 471 阅读 · 0 评论 -
数组中出现次数超过一半的数字
题目描述数组中有一个数字出现的次数超过数组长度的一半,请找出这个数字。例如输入一个长度为9的数组{1,2,3,2,2,2,5,4,2}。由于数字2在数组中出现了5次,超过数组长度的一半,因此输出2。如果不存在则输出0。思路方法一排序,使用sort进行排序。如果数组中存在出现次数超过数组一半的,那么它只可能是中位数。扫描统计中位数出现次数,超过一半则返回。 时间复杂度:O(nlog...原创 2018-04-04 15:36:28 · 122 阅读 · 0 评论 -
连续子数组最大和
题目描述HZ偶尔会拿些专业问题来忽悠那些非计算机专业的同学。今天测试组开完会后,他又发话了:在古老的一维模式识别中,常常需要计算连续子向量的最大和,当向量全为正数的时候,问题很好解决。但是,如果向量中包含负数,是否应该包含某个负数,并期望旁边的正数会弥补它呢?例如:{6,-3,-2,7,-15,1,2,2},连续子向量的最大和为8(从第0个开始,到第3个为止)。你会不会被他忽悠住?(子向量的长度至...转载 2018-04-04 17:36:43 · 99 阅读 · 0 评论 -
把数组排成最小的数
题目描述输入一个正整数数组,把数组里所有数字拼接起来排成一个数,打印能拼接出的所有数字中最小的一个。例如输入数组{3,32,321},则打印出这三个数字能排成的最小数字为321323。解题思路可以说是十分暴力了 * 先将整型数组转换成String数组,然后将String数组排序,最后将排好序的字符串数组拼接出来。关键就是制定排序规则。 * 排序规则如下: * 若ab > ba 则 a >...转载 2018-04-05 11:08:26 · 77 阅读 · 0 评论 -
丑数
题目描述把只包含因子2、3和5的数称作丑数(Ugly Number)。例如6、8都是丑数,但14不是,因为它包含因子7。 习惯上我们把1当做是第一个丑数。求按从小到大的顺序的第N个丑数。思路这题应该按照动态规划的思路来做。参考思路:如果p是丑数,那么p=2^x * 3^y * 5^z那么只要赋予x,y,z不同的值就能得到不同的丑数。如果要顺序找出丑数,要知道下面几个特(fei)点(hua)。对于任...原创 2018-04-05 14:42:47 · 104 阅读 · 0 评论 -
第一个出现一次的字符
题目描述在一个字符串(1<=字符串长度<=10000,全部由字母组成)中找到第一个只出现一次的字符,并返回它的位置。主要学习map的使用class Solution {public:int FirstNotRepeatingChar(string str) { map<char, int> mp; for(int i = 0; i <...原创 2018-04-05 22:00:17 · 87 阅读 · 0 评论 -
数据流中的中位数
题目描述如何得到一个数据流中的中位数?如果从数据流中读出奇数个数值,那么中位数就是所有数值排序之后位于中间的数值。如果从数据流中读出偶数个数值,那么中位数就是所有数值排序之后中间两个数的平均值。堆实现链接:https://www.nowcoder.com/questionTerminal/9be0172896bd43948f8a32fb954e1be1来源:牛客网class Solution...原创 2018-04-12 23:46:10 · 194 阅读 · 0 评论 -
二叉树中和为某一值的路径
题目描述输入一颗二叉树和一个整数,打印出二叉树中结点值的和为输入整数的所有路径。路径定义为从树的根结点开始往下一直到叶结点所经过的结点形成一条路径。思路采用递归,唯一的问题是怎么返回结果。如何保存当前路径。/*struct TreeNode { int val; struct TreeNode *left; struct TreeNode *right; TreeNode(int x) ...原创 2018-04-02 11:19:49 · 88 阅读 · 0 评论 -
二叉搜索树的后序遍历
题目描述输入一个整数数组,判断该数组是不是某二叉搜索树的后序遍历的结果。如果是则输出Yes,否则输出No。假设输入的数组的任意两个数字都互不相同。思路采用递归方法#include<iostream>#include<vector>#include<limits.h>using namespace std;bool core(vector<int&g...原创 2018-04-01 23:07:52 · 83 阅读 · 0 评论 -
从尾到头打印链表
题目描述输入一个链表,从尾到头打印链表每个节点的值。/*** struct ListNode {* int val;* struct ListNode *next;* ListNode(int x) :* val(x), next(NULL) {* }* };*/class Solution {...原创 2018-03-23 16:54:01 · 93 阅读 · 0 评论 -
重建二叉树
题目描述输入某二叉树的前序遍历和中序遍历的结果,请重建出该二叉树。假设输入的前序遍历和中序遍历的结果中都不含重复的数字。例如输入前序遍历序列{1,2,4,7,3,5,6,8}和中序遍历序列{4,7,2,1,5,3,8,6},则重建二叉树并返回。递归调用/** * Definition for binary tree * struct TreeNode { * int val; * ...原创 2018-03-24 10:49:48 · 91 阅读 · 0 评论 -
用两个栈实现队列
题目描述用两个栈来实现一个队列,完成队列的Push和Pop操作。 队列中的元素为int类型。STL之stack1.声明一个stack stack<int> s1; stack<string> s2;2.stack中的操作 stack<int> s; s.push(x) 无返回值,将元素x压栈 s.pop(); 退栈...原创 2018-03-24 11:19:53 · 102 阅读 · 0 评论 -
旋转数组的最小数字
题目描述把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转。 输入一个非递减排序的数组的一个旋转,输出旋转数组的最小元素。 例如数组{3,4,5,1,2}为{1,2,3,4,5}的一个旋转,该数组的最小值为1。 NOTE:给出的所有元素都大于0,若数组大小为0,请返回0。链接:https://www.nowcoder.com/questionTerminal/9f3231a991af...转载 2018-03-24 15:06:57 · 95 阅读 · 0 评论 -
跳台阶
题目描述一只青蛙一次可以跳上1级台阶,也可以跳上2级。求该青蛙跳上一个n级的台阶总共有多少种跳法。思路最后一跳可以分为两种情况,跳一级和跳两级,所以有F(n) = F(n-1) + F(n-2)即为,斐波那契数列class Solution {public: int jumpFloor(int number) { vector<int> ver; ...原创 2018-03-24 22:59:53 · 83 阅读 · 0 评论 -
变态跳台阶
题目描述一只青蛙一次可以跳上1级台阶,也可以跳上2级……它也可以跳上n级。求该青蛙跳上一个n级的台阶总共有多少种跳法。class Solution {public: int jumpFloorII(int number) { vector<int> ver; int temp, j; int tmp = 0; i...原创 2018-03-24 23:36:39 · 81 阅读 · 0 评论 -
数组中只出现一次的数字
题目描述一个整型数组里除了两个数字之外,其他的数字都出现了两次。请写程序找出这两个只出现一次的数字。思路方法一:最直观的想法就是,将所有的数字进行排序。这样的话两个相同数字就会相邻。我们只需找出两个数字,这两个数字与他两边的数字均不相同。时间复杂度:O(nlogn)方法二:更好的方法是利用题中相同数字只出现两次的特性。利用异或运算解决。首先:位运算中异或的性...原创 2018-04-07 17:57:32 · 86 阅读 · 0 评论 -
树的子结构*
题目描述输入两棵二叉树A,B,判断B是不是A的子结构。(ps:我们约定空树不是任意一个树的子结构)/*struct TreeNode { int val; struct TreeNode *left; struct TreeNode *right; TreeNode(int x) : val(x), left(NULL), right(NULL) { }};*/class S...原创 2018-03-30 21:58:19 · 113 阅读 · 0 评论 -
顺时针打印矩阵
题目描述输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字,例如,如果输入如下矩阵: 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.思路这道题太容易错了。算出需要循环几个圈,最后多余的一排(或一列)单独处理;在每一圈写四个循环,分别处理一个圈的四边,注意边角的处理...原创 2018-03-31 10:42:59 · 128 阅读 · 0 评论 -
包含min函数的栈
题目描述定义栈的数据结构,请在该类型中实现一个能够得到栈最小元素的min函数。class Solution { stack<int> s,mins;public: void push(int value) { s.push(value); if(mins.empty()) mins.push(value); ...原创 2018-03-31 10:58:06 · 85 阅读 · 0 评论 -
二进制中1的个数
题目描述输入一个整数,输出该数二进制表示中1的个数。其中负数用补码表示。位运算class Solution {public: int NumberOf1(int n){ int counter = 0; unsigned int flag = 1; while(flag) { if(n & flag) { ...原创 2018-03-25 22:25:40 · 82 阅读 · 0 评论 -
数值的整数次方
题目描述给定一个double类型的浮点数base和int类型的整数exponent。求base的exponent次方。思路方法一:调用 double pow(double num, int pow)函数,cmath方法二:形如y= y * x方法三:位运算 1.全面考察指数的正负、底数是否为零等情况。 2.写出指数的二进制表达,例如1...原创 2018-03-25 23:22:11 · 98 阅读 · 0 评论 -
调整数组顺序使奇数位于偶数之前
题目描述输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有的奇数位于数组的前半部分,所有的偶数位于位于数组的后半部分,并保证奇数和奇数,偶数和偶数之间的相对位置不变。思路方法一:类似于冒泡排序的方法方法二:从前到后扫描,遇到偶数就删除,并在队尾插入。#include<iostream>#include<vector>using namespace std;...原创 2018-03-26 11:30:44 · 105 阅读 · 0 评论 -
栈的压入弹出序列
题目描述输入两个整数序列,第一个序列表示栈的压入顺序,请判断第二个序列是否为该栈的弹出顺序。假设压入栈的所有数字均不相等。例如序列1,2,3,4,5是某栈的压入顺序,序列4,5,3,2,1是该压栈序列对应的一个弹出序列,但4,3,5,1,2就不可能是该压栈序列的弹出序列。(注意:这两个序列的长度是相等的)进行栈压入弹出的模拟class Solution {public: bool IsP...原创 2018-04-01 00:00:28 · 109 阅读 · 0 评论 -
不用加减乘除做加法
题目描述写一个函数,求两个整数之和,要求在函数体内不得使用+、-、*、/四则运算符号。思路首先看十进制是如何做的: 5+7=12,三步走第一步:相加各位的值,不算进位,得到2。第二步:计算进位值,得到10. 如果这一步的进位值为0,那么第一步得到的值就是最终结果。第三步:重复上述两步,只是相加的值变成上述两步的得到的结果2和10,得到12。同样我们可以用三步走的方式计算二进制值相加: 5-101,...转载 2018-04-08 22:47:06 · 84 阅读 · 0 评论 -
滑动窗口的最大值 —— STL之deque
题目描述给定一个数组和滑动窗口的大小,找出所有滑动窗口里数值的最大值。例如,如果输入数组{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],2,6,2,5,1}, {2,[3,4,2],6,2,5,1}, {2,3,[4,2,6],2,5,...原创 2018-04-13 17:15:53 · 754 阅读 · 0 评论