
剑指Offer
AQH~
学习中寻找快乐。。。
展开
-
数组中的逆序对(时间空间效率的平衡)
题目描述在数组中的两个数字,如果前面一个数字大于后面的数字,则这两个数字组成一个逆序对。输入一个数组,求出这个数组中的逆序对的总数P。并将P对1000000007取模的结果输出。 即输出P%1000000007输入描述题目保证输入的数组中没有的相同的数字数据范围: 对于%50的数据,size<=10^4 对于%75的数据,size<=10^5 对于%100的数据,size<=2*...原创 2018-07-09 09:36:19 · 278 阅读 · 0 评论 -
第一个只出现一次的字符位置(时间空间效率的平衡)
题目描述在一个字符串(0<=字符串长度<=10000,全部由字母组成)中找到第一个只出现一次的字符,并返回它的位置, 如果没有则返回 -1(需要区分大小写).思路我开始这样想的,利用map统计,但是map会改变顺序,怎么办呢?再用个辅助数组记录位置,好麻烦啊。回头再想没那么麻烦,首先统计,然后从头开始遍历原字符串,找到第一个终止即可。因为全是字母,可以利用ASCII码的值,...原创 2018-08-13 08:54:24 · 148 阅读 · 0 评论 -
数组中只出现一次的数字( 知识迁移能力)
题目描述一个整型数组里除了两个数字之外,其他的数字都出现了偶数次。请写程序找出这两个只出现一次的数字。思路这个不可以利用数组下标,利用map还是会改变顺序,还需要遍历数组。利用set进行插入、查询、删除最后剩余的两个就是答案,但是set是排过序的,也有瑕疵。怎么办?可以用vector的插入、查询、删除、但是操作比set稍微麻烦一点。//错误,最后两个数已排好序了void Fin...原创 2018-08-13 09:25:25 · 173 阅读 · 0 评论 -
把数组排成最小的数( 时间效率)
题目描述输入一个正整数数组,把数组里所有数字拼接起来排成一个数,打印能拼接出的所有数字中最小的一个。例如输入数组{3,32,321},则打印出这三个数字能排成的最小数字为321323。思路刚开始,毫无头绪,反正就知道是排序,是比较每一位还是怎么处理,搞不清。看了好久,突然发现就是一个谁放前面谁放后面的问题,字符串拼接,比如A和B两个数字,是AB大还是BA大,冒泡排序。每次一个值归位。...原创 2018-08-13 09:41:33 · 184 阅读 · 0 评论 -
和为S的两个数字( 知识迁移能力)
题目描述输入一个递增排序的数组和一个数字S,在数组中查找两个数,使得他们的和正好是S,如果有多对数字的和等于S,输出两个数的乘积最小的。输出描述:对应每个测试案例,输出两个数,小的先输出。思路首先知道有序,肯定是两个数的差越大,乘积越小。从前往后找,第一个一定是最小的。遍历+二分,从前开始遍历,确定一个数,剩余一个数二分查找。vector<int> Find...原创 2018-08-13 09:46:09 · 150 阅读 · 0 评论 -
左旋转字符串(知识迁移能力)
题目描述汇编语言中有一种移位指令叫做循环左移(ROL),现在有个简单的任务,就是用字符串模拟这个指令的运算结果。对于一个给定的字符序列S,请你把其循环左移K位后的序列输出。例如,字符序列S=”abcXYZdef”,要求输出循环左移3位后的结果,即“XYZdefabc”。是不是很简单?OK,搞定它!思路简单的字符串模拟,可以用Java,字符串的截取和拼接都很简单。/发现这里的题,都...原创 2018-08-13 09:49:11 · 175 阅读 · 0 评论 -
变态跳台阶(递归和循环)
题目描述一只青蛙一次可以跳上1级台阶,也可以跳上2级……它也可以跳上n级。求该青蛙跳上一个n级的台阶总共有多少种跳法。思路n=1,ans=1n=2,ans=2n=3, ans=4(n=3,可以由n=1和n=2直接跳上来,别忘了还有一个可以直接跳上来不经过任何台阶)n=4, ans=8n=5, ans=16int jumpFloorII(int number) ...原创 2018-08-08 16:36:59 · 496 阅读 · 0 评论 -
求1+2+3+...+n(发散思维能力)
题目描述求1+2+3+...+n,要求不能使用乘除法、for、while、if、else、switch、case等关键字及条件判断语句(A?B:C)。int ans=0;int fun(int n){ return n && (ans+=n,fun(n-1)); //&&执行一半,不符合就不执行了}int Sum_Solution(in...原创 2018-08-08 16:52:47 · 232 阅读 · 0 评论 -
京东2019校招在线考试(算法岗)
思路:感觉还是题目描述有点问题。错误思路:题意没有读清,一直以为S串去替换T串,如测试数据(ababcb替换后xyxyxy,与xyx进行匹配,大眼一看不错结果就是三个,然后突然想到最长公共子序列的出现次数,我擦,敲出代码发现就是结果不对,尴尬,什么原因,找了半天没有发现错误何在,最后发现xyxyxy去匹配xyx不是3是4,(xyxyxy)(xyxyxy)(xyxyxy)(xyxyxy))。...原创 2018-09-10 14:24:49 · 1743 阅读 · 0 评论 -
凹凸函数
我擦,迷瞪了一上午,还以为人家题目出错了,凹凸函数在同济大学高等数学中的定义符合人们的思维定式。在国际上的定义恰好与同济大学高等数学中的定义相反。1、同济大学高等数学定义:2、国际上的定义:国际上的定义刚好与国内的凹凸函数的定义相反。二阶导数大于0,则为凸函数,有极小值;二阶导数小于0,则为凹函数,有极大值(后面涉及到的凹凸函数,均为国际上的定义);3、e^x的二阶导数大于0,...原创 2018-09-18 15:39:03 · 43084 阅读 · 1 评论 -
小试牛刀(二)
思路:再来读一遍题目,就是一个取石子游戏,首先肯定第一反应就是暴力啊,暴力k值,然后直到找到满足条件的最小的k值结束,但是肯定会超时。我开始有闪过这样一个想法,都是错误的哈(只要取大于等于一半即可,妞妞取得一半是最少的,牛牛取得一半消耗的次数,然后去除,直接得到m,哈哈牛牛的每次取值是总数的1/10,不断变化的)。其实很简单k值得取值范围1~1^18,二分找到满足条件的k值啊,long lon...原创 2018-10-08 10:48:57 · 422 阅读 · 0 评论 -
求幂(京东2018秋招)
东东对幂运算很感兴趣,在学习的过程中东东发现了一些有趣的性质: 9^3 = 27^2, 2^10 = 32^2东东对这个性质充满了好奇,东东现在给出一个整数n,希望你能帮助他求出满足 a^b = c^d(1 ≤ a,b,c,d ≤ n)的式子有多少个。例如当n = 2: 1^1=1^11^1=1^21^2=1^11^2=1^22^1=2^12^2=2^2一共有6个满足要求的式子...原创 2018-10-09 08:41:07 · 1083 阅读 · 0 评论 -
判断图中是否存在环
1、无向图①拓扑排序(判断是否有环)②深度优先搜索(判断是否有环)③dfs+辅助栈(确定环的路径)2、有向图①拓扑排序(判断是否有环)②深度优先搜索(判断是否有环)③dfs+辅助栈(确定环的路径)错误代码(刚开始这样想,但是不正确)①遍历每一个点,然后判断是否能够走回到原点,这样容易出现大量重复。#include<stdio.h>#inclu...原创 2019-03-06 16:35:26 · 4876 阅读 · 0 评论 -
三星研究院上机题(Common Ancestor in Tree)
You are to find the closest common ancestor of two vertices in a binary tree. For example, the common ancestors of vertices 8 and 13 in the figure below are vertices 3 and 1. Among them, vertex ...原创 2019-03-04 08:35:11 · 3073 阅读 · 3 评论 -
三星研究院上机题(Optimal Path)
Mr. Kim has to deliver refrigerators to N customers. From the office, he is going to visit all the customers and then return to his home. Each location of the office, his home, and the customers is gi...原创 2019-03-04 14:50:35 · 3933 阅读 · 8 评论 -
三星研究院上机题(Order of task)
Thereare V tasks to do. Some task(s) can begin only after a particular task ends,which we will call precedence relation. A graph indicating precedence relationof tasks is given. In this graph, each ta...原创 2019-03-04 16:06:10 · 3182 阅读 · 4 评论 -
连续子串和
1、给出一个序列,求连续子串和的最大值,要求在O(n)求解思路:积分图+两层for循环遍历起始位置和终止位置,O(n^2)最优思路:依次累加,并不断更新Max,在累加的过程中,若sum小于0,更新开始位置。其实这个更新位置我纠结很久,这里若第i位sum<0,sum从下一位开始累加求和。第i要是为正数怎么办?怎么可能,sum(i-1)+a[i]<0,sum(i-1)要求是大于...原创 2019-08-06 14:34:18 · 710 阅读 · 0 评论 -
数字在排序数组中出现的次数(知识迁移能力)
题目描述统计一个数字在排序数组中出现的次数。思路有序,二分查找,定位成功后,向前向后统计。int GetNumberOfK(vector<int> a ,int k) { int n=a.size(); int l=0,r=n-1; int p=-1,sum=0; while(l<=r){ int mid=(l+...原创 2018-08-13 08:49:37 · 139 阅读 · 0 评论 -
最小的K个数( 时间效率 )
题目描述输入n个整数,找出其中最小的K个数。例如输入4,5,1,6,2,7,3,8这8个数字,则最小的4个数字是1,2,3,4,。思路这一题很简单的想到了堆排序,堆排序就是每次归位一个最大值/最小值,直接上代码,堆排序。void MaxHeap(int a[],int n){ //数组辅组,找到第一个有孩子的节点 for(int i=n/2-1;i>=0;...原创 2018-08-13 08:45:33 · 195 阅读 · 0 评论 -
华为研发工程师编程题
1有这样一道智力题:“某商店规定:三个空汽水瓶可以换一瓶汽水。小张手上有十个空汽水瓶,她最多可以换多少瓶汽水喝?”答案是5瓶,方法如下:先用9个空瓶子换3瓶汽水,喝掉3瓶满的,喝完以后4个空瓶子,用3个再换一瓶,喝掉这瓶满的,这时候剩2个空瓶子。然后你让老板先借给你一瓶汽水,喝掉这瓶满的,喝完以后用3个空瓶子换一瓶满的还给老板。如果小张手上有n个空汽水瓶,最多可以换多少瓶汽水喝? 思路题意很清楚,...原创 2018-07-09 10:41:10 · 253 阅读 · 0 评论 -
二维数组中的查找( 数组)
题目描述在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序。请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数。思想①因为有序,所以二分查找。②从上到下,从左到右,都是递增。但是把二维变成一维之后就不是递增的了②行进行二分查找,确定在哪一行,再在行上确定是哪一列。本来以为用非递归思想可以解决问题,但是会出现分叉,只能用递归。情况一:在行...原创 2018-07-02 16:56:29 · 1781 阅读 · 0 评论 -
华为2016校园招聘上机笔试题
1老师想知道从某某同学当中,分数最高的是多少,现在请你编程模拟老师的询问。当然,老师有时候需要更新某位同学的成绩.思路:①区间最大值,点更新。这里是最简单的,其实还有区间求和,区间最大值,区间最小值,点更新,区间更新。可以用线段树、树状数组、RMQ①这里只简单说明一下区间最大值和点更新,剩余的放在下一个篇详细介绍。②就用线段树吧,n个数据,就是n个叶子节点存放数据。父节...原创 2018-07-10 09:46:03 · 2912 阅读 · 0 评论 -
替换空格(字符串)
题目描述请实现一个函数,将一个字符串中的空格替换成“%20”。例如,当字符串为We Are Happy.则经过替换之后的字符串为We%20Are%20Happy。思路①本来以为很麻烦,如果使用C/C++需要开辟内存空间,毕竟字符串变长了。可能设计者很人性化,定义了一个很大的数组,当参数传入。②使用C/C++不需要返回值,使用的是指针。用Java和python需要返回值,利用库函数也比较简单。③还是...原创 2018-07-03 08:58:20 · 733 阅读 · 0 评论 -
斐波那契数列(递归和循环)
题目描述大家都知道斐波那契数列,现在要求输入一个整数n,请你输出斐波那契数列的第n项。n<=39思路①递归②非递归③打表代码#include<stdio.h>#include<string.h>//递归,超时int Fibonacci(int n){ if(n==1||n==2) return 1; return Fibonacc...原创 2018-07-03 09:14:38 · 2313 阅读 · 0 评论 -
跳台阶(递归和循环)
题目描述一只青蛙一次可以跳上1级台阶,也可以跳上2级。求该青蛙跳上一个n级的台阶总共有多少种跳法。思路题目很简单,如果洞悉出考什么,那就很简单了,就是一个斐波那契数列。这样想,当前台阶只可能由下一层跳一层上来,也可以由下两层台阶一次跳两层上来。只与前两层有关,f(n)=f(n-1)+f(n-2),(注意与斐波那契区别是开始的值不同,一个是1,1,2,3,5;一个是1,2,3,5)代码#includ...原创 2018-07-03 09:32:42 · 770 阅读 · 0 评论 -
二进制中1的个数(位运算)
题目描述输入一个整数,输出该数二进制表示中1的个数。其中负数用补码表示。思路①正数,很好解决该问题②负数,如何呢?首先数据类型是int,4字节32位,负数统计的是补码中的1,可以先取反(取反操作是 在补码上进行的,且全部位都取反,负数都变成了正数,然后统计正数的1),再用互补原则32-sum,即可。③其实不需要考虑怎么存储,从最低位开始与运算即可。int范围也就32位,移出界就变成0了,结束whi...原创 2018-07-03 13:46:40 · 615 阅读 · 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.思路就是一个模拟题,不一定是个方形矩阵,注意特殊的行矩阵和列矩阵。左上角坐标(s0,s1)和右下角坐标(e0,e1)代码...原创 2018-07-05 09:28:09 · 229 阅读 · 0 评论 -
翻转单词顺序列(知识迁移能力)
题目描述牛客最近来了一个新员工Fish,每天早晨总是会拿着一本英文杂志,写些句子在本子上。同事Cat对Fish写的内容颇感兴趣,有一天他向Fish借来翻看,但却读不懂它的意思。例如,“student. a am I”。后来才意识到,这家伙原来把句子单词的顺序翻转了,正确的句子应该是“I am a student.”。Cat对一一的翻转这些单词顺序可不在行,你能帮助他么?思路①很简单的一道题,但是如...原创 2018-07-05 14:04:14 · 271 阅读 · 0 评论 -
丑数(时间空间效率的平衡)
题目描述把只包含因子2、3和5的数称作丑数(Ugly Number)。例如6、8都是丑数,但14不是,因为它包含因子7。 习惯上我们把1当做是第一个丑数。求按从小到大的顺序的第N个丑数。思路①打表②set集合(自动排序)代码...原创 2018-07-06 17:26:42 · 336 阅读 · 0 评论 -
RMQ、树状数组、线段树
1、线段树(区间求和、区间最大值、区间最小值)2、树状数组3、RMQ(区间最大值、区间最小值)原创 2018-07-16 09:06:05 · 642 阅读 · 0 评论 -
扑克牌顺子(抽象建模能力)
题目描述LL今天心情特别好,因为他去买了一副扑克牌,发现里面居然有2个大王,2个小王(一副牌原本是54张^_^)...他随机从中抽出了5张牌,想测测自己的手气,看看能不能抽到顺子,如果抽到的话,他决定去买体育彩票,嘿嘿!!“红心A,黑桃3,小王,大王,方片5”,“Oh My God!”不是顺子.....LL不高兴了,他想了想,决定大\小 王可以看成任何数字,并且A看作1,J为11,Q为12,K...原创 2018-08-09 08:05:31 · 229 阅读 · 0 评论 -
数组中出现次数超过一半的数字( 时间效率)
题目描述数组中有一个数字出现的次数超过数组长度的一半,请找出这个数字。例如输入一个长度为9的数组{1,2,3,2,2,2,5,4,2}。由于数字2在数组中出现了5次,超过数组长度的一半,因此输出2。如果不存在则输出0。思路:第一步:排序第二部:统计,有点小技巧,第i个和第i+(n/2)个要是相等则直接结束。int MoreThanHalfNum_Solution(vector...原创 2018-08-09 08:14:00 · 136 阅读 · 0 评论 -
正则表达式匹配(字符串)
题目描述请实现一个函数用来匹配包括'.'和'*'的正则表达式。模式中的字符'.'表示任意一个字符,而'*'表示它前面的字符可以出现任意次(包含0次)。 在本题中,匹配是指字符串的所有字符匹配整个模式。例如,字符串"aaa"与模式"a.a"和"ab*ac*a"匹配,但是与"aa.a"和"ab*a"均不匹配思路首先这道题目要滤清思路,一个字符串去和模式串进行匹配。分二种情况①相等(需要...原创 2018-08-14 08:32:29 · 4776 阅读 · 0 评论 -
连续子数组的最大和(时间效率)
题目描述HZ偶尔会拿些专业问题来忽悠那些非计算机专业的同学。今天测试组开完会后,他又发话了:在古老的一维模式识别中,常常需要计算连续子向量的最大和,当向量全为正数的时候,问题很好解决。但是,如果向量中包含负数,是否应该包含某个负数,并期望旁边的正数会弥补它呢?例如:{6,-3,-2,7,-15,1,2,2},连续子向量的最大和为8(从第0个开始,到第3个为止)。给一个数组,返回它的最大连续子序...原创 2018-08-13 08:09:57 · 836 阅读 · 0 评论 -
整数中1出现的次数(从1到n整数中1出现的次数)( 时间效率)
题目描述求出1~13的整数中1出现的次数,并算出100~1300的整数中1出现的次数?为此他特别数了一下1~13中包含1的数字有1、10、11、12、13因此共出现6次,但是对于后面问题他就没辙了。ACMer希望你们帮帮他,并把问题更加普遍化,可以很快的求出任意非负整数区间中1出现的次数(从1 到 n 中1出现的次数)。思路①暴力循环遍历,易超时。②设N = abcde ,其中ab...原创 2018-08-13 08:37:01 · 189 阅读 · 0 评论 -
子串最长的斐波那契数列
思路:暴力,枚举斐波那契数列开始的两个值。若长度为2的时候,输出0时间复杂度有点高,有没有什么优化的方式呢?①错误思路:把每次出现的斐波那契数列标记一下,如果下次开始的两个值都出现过,那么就结束。1 2 3 5 8 (1和2开始,依次标记3,5,8,后续遍历2和3的时候就可以直接终止了)错误原因:没有考虑到标记的两个数可能不是同一个斐波那契数列得到的5 7 9 1...原创 2019-09-06 08:42:15 · 594 阅读 · 0 评论