新鲜出炉:微软等数据结构+算法面试100题最后20题

微软等数据结构+算法面试100题最后20题第81-100题新鲜出炉

---100题系列V0.1版完整公布

作者:July

时间:2010年12月5日

-------------

<!--EndFragment-->

首先,非常感谢各位,对本微软面试100题系列前期工作的大力支持。
很多很多热心的网友,积极参与进来,或在我的帖子上一起做,
或对已经上传的答案,对每一题的算法提出批评指正,
[同时,我也将永远、继续不断优化、改进每一题的算法,直到极限。]
或在我的博客里留言,大力支持的,
在此,向各位一致表示最衷心的感谢。

本来,整理这样一套微软等100题系列,需要大量的时间与精力,
很多的事,都因为它而被迫搁浅,但想到我做的这件事,将造益许多的人,
人人为我,我为人人,大家享受开源、思考的乐趣,
感受彼此思维的碰撞,这是一件来之不易、且意义非凡的事。
特此,刚刚整理完了此100题系列的最后20道题,现在立马公布出来。

由于答案的整理不像题目那般,除了自己所有的,还可以从网上搜集,
而这个答案,全都得由自己去想、去做,更是由于这些题现已经有近10万人看到或见识到。
如此,更兼诚惶诚恐,不敢大肆造次。
我也将,更加细致的整理本100题V0.1版最后60题第41题-100题的答案,
所以希望,各位更加耐心的等待。

同时,希望,各位网友能更多的、更好的提出你的个人思路、算法,
一经采纳,我会在随后的答案整理中,附上你的思路和姓名。
谢谢。

然后,由于本微软等100题系列,现在完整出完了V0.1版,
以后将会陆续推出V0.2版,V0.3版V1.0最终完美版,
因为我手头里已经整理到了第201题,我不会因为只出100道而被限制。
所以,接下来,出完这最初的V0.1版本之后,
我将会不断出同样来自微软等数家大公司更具价值更精彩的另外不同的100道题,
请,继续关注。谢谢。

最后,我将把我这所有的工作,写成一本书,先放在网上免费阅读。
以最大的无私奉献给各位最热心的网友们。谢谢,你们。

目前,我要建一个100题各版本维护组,专门针对这100题各个版本进行维护、修正
此事,我会日后再博客里,详细阐述。有意愿,欢迎联系我。:D。
//预计本微软等面试100题系列V0.2版,相信,会在明年2011年与大家见面,具体待定。

好了,说了这么多,接下来,请继续尽情的享用:
本微软等100 题系列V0.1 版前80 题:

http://blog.csdn.net/v_JULY_v/archive/2010/11/27/6039896.aspx

先来,几组百度的面试题:
======================
81.第1组百度面试题
1.一个int数组,里面数据无任何限制,要求求出所有这样的数a[i],
其左边的数都小于等于它,右边的数都大于等于它。
能否只用一个额外数组和少量其它空间实现。
2.一个文件,内含一千万行字符串,每个字符串在1K以内,
要求找出所有相反的串对,如abc和cba。
3.STL的set用什么实现的?为什么不用hash?

82.第2组百度面试题
1.给出两个集合A和B,其中集合A={name},
集合B={age、sex、scholarship、address、...},
要求:
问题1、根据集合A中的name查询出集合B中对应的属性信息;
问题2、根据集合B中的属性信息(单个属性,如age<20等),查询出集合A中对应的name。

2.给出一个文件,里面包含两个字段{url、size},
即url为网址,size为对应网址访问的次数,
要求:
问题1、利用Linux Shell命令或自己设计算法,
查询出url字符串中包含“baidu”子字符串对应的size字段值;
问题2、根据问题1的查询结果,对其按照size由大到小的排列。
(说明:url数据量很大,100亿级以上)

83.第3组百度面试题
1.今年百度的一道题目
百度笔试:给定一个存放整数的数组,重新排列数组使得数组左边为奇数,右边为偶数。
要求:空间复杂度O(1),时间复杂度为O(n)。

2.百度笔试题
用C语言实现函数void * memmove(void *dest, const void *src, size_t n)。
memmove函数的功能是拷贝src所指的内存内容前n个字节到dest所指的地址上。
分析:
由于可以把任何类型的指针赋给void类型的指针
这个函数主要是实现各种数据类型的拷贝。

84.第4组百度面试题
2010年3道百度面试题[相信,你懂其中的含金量]
1.a~z包括大小写与0~9组成的N个数
用最快的方式把其中重复的元素挑出来。
2.已知一随机发生器,产生0的概率是p,产生1的概率是1-p,现在要你构造一个发生器,
使得它构造0和1的概率均为1/2;构造一个发生器,使得它构造1、2、3的概率均为1/3;...,
构造一个发生器,使得它构造1、2、3、...n的概率均为1/n,要求复杂度最低。
3.有10个文件,每个文件1G,
每个文件的每一行都存放的是用户的query,每个文件的query都可能重复。
要求按照query的频度排序.

85.又见字符串的问题
1.给出一个函数来复制两个字符串A和B。
字符串A的后几个字节和字符串B的前几个字节重叠。
分析:记住,这种题目往往就是考你对边界的考虑情况。
2.已知一个字符串,比如asderwsde,寻找其中的一个子字符串比如sde的个数,
如果没有返回0,有的话返回子字符串的个数。

86.
怎样编写一个程序,把一个有序整数数组放到二叉树中?
分析:二叉搜索树的建树方法。简单的递归结构。实在不理解,干脆记下来好了。
关于树的算法设计一定要联想到递归,因为树本身就是递归的定义。

这里的递归应该是理所当然的吧,不过,学会把递归改称非递归也是一种必要的技术。
毕竟,递归会造成栈溢出,关于系统底层的程序中不到非不得以最好不要用。
但是对某些数学问题,就一定要学会用递归去解决。

87.
1.大整数数相乘的问题。(这是2002年在一考研班上遇到的算法题)
2.求最大连续递增数字串(如“ads3sl456789DF3456ld345AA”中的“456789”)
3.实现strstr功能,即在父串中寻找子串首次出现的位置。
(笔试中常让面试者实现标准库中的一些函数)


88.2005年11月金山笔试题。编码完成下面的处理函数。
函数将字符串中的字符'*'移到串的前部分,

前面的非'*'字符后移,但不能改变非'*'字符的先后顺序,函数返回串中字符'*'的数量。
如原始串为:ab**cd**e*12,
处理后为*****abcde12,函数并返回值为5。(要求使用尽量少的时间和辅助空间)

89.神州数码、华为、东软笔试题
1.2005年11月15日华为软件研发笔试题。实现一单链表的逆转。
2.编码实现字符串转整型的函数(实现函数atoi的功能),据说是神州数码笔试题。如将字符
串 ”+123”123, ”-0123”-123, “123CS45”123, “123.45CS”123, “CS123.45”0
3.快速排序(东软喜欢考类似的算法填空题,又如堆排序的算法等)
4.删除字符串中的数字并压缩字符串。
如字符串”abc123de4fg56”处理后变为”abcdefg”。注意空间和效率。
(下面的算法只需要一次遍历,不需要开辟新空间,时间复杂度为O(N))
5.求两个串中的第一个最长子串(神州数码以前试题)。
如"abractyeyt","dgdsaeactyey"的最大子串为"actyet"。

90.
1.不开辟用于交换数据的临时空间,如何完成字符串的逆序
(在技术一轮面试中,有些面试官会这样问)。
2.删除串中指定的字符
(做此题时,千万不要开辟新空间,否则面试官可能认为你不适合做嵌入式开发)
3.判断单链表中是否存在环。

91.
1.一道著名的毒酒问题
有1000桶酒,其中1桶有毒。而一旦吃了,毒性会在1周后发作。
现在我们用小老鼠做实验,要在1周内找出那桶毒酒,问最少需要多少老鼠。
2.有趣的石头问题
有一堆1万个石头和1万个木头,对于每个石头都有1个木头和它重量一样,
把配对的石头和木头找出来。

92.
1.多人排成一个队列,我们认为从低到高是正确的序列,但是总有部分人不遵守秩序。
如果说,前面的人比后面的人高(两人身高一样认为是合适的),
那么我们就认为这两个人是一对“捣乱分子”,比如说,现在存在一个序列:
176, 178, 180, 170, 171
这些捣乱分子对为
<176, 170>, <176, 171>, <178, 170>, <178, 171>, <180, 170>, <180, 171>,
那么,现在给出一个整型序列,请找出这些捣乱分子对的个数(仅给出捣乱分子对的数目即可,不用具体的对)

要求:
输入:
为一个文件(in),文件的每一行为一个序列。序列全为数字,数字间用”,”分隔。
输出:
为一个文件(out),每行为一个数字,表示捣乱分子的对数。

详细说明自己的解题思路,说明自己实现的一些关键点。
并给出实现的代码 ,并分析时间复杂度。
限制:
输入每行的最大数字个数为100000个,数字最长为6位。程序无内存使用限制。

93.在一个int数组里查找这样的数,它大于等于左侧所有数,小于等于右侧所有数。
直观想法是用两个数组a、b。a[i]、b[i]分别保存从前到i的最大的数和从后到i的最小的数,

一个解答:这需要两次遍历,然后再遍历一次原数组,
将所有data[i]>=a[i-1]&&data[i]<=b[i]的data[i]找出即可。

给出这个解答后,面试官有要求只能用一个辅助数组,且要求少遍历一次。

94.微软笔试题
求随机数构成的数组中找到长度大于=3的最长的等差数列9 d- x' W) w9 ?" o3 b0 R
输出等差数列由小到大:
如果没有符合条件的就输出
格式:
输入[1,3,0,5,-1,6]
输出[-1,1,3,5]
要求时间复杂度,空间复杂度尽量小

95.华为面试题
1 判断一字符串是不是对称的,如:abccba
2.用递归的方法判断整数组a[N]是不是升序排列

96.08年中兴校园招聘笔试题
1.编写strcpy 函数
已知strcpy 函数的原型是
char *strcpy(char *strDest, const char *strSrc);
其中strDest 是目的字符串,strSrc 是源字符串。不调用C++/C 的字符串库函数,请
编写函数 strcpy


最后压轴之戏,终结此微软等100题系列V0.1版。
那就,
连续来几组微软公司的面试题,让你一次爽个够:
======================
97.第1组微软较简单的算法面试题
1.编写反转字符串的程序,要求优化速度、优化空间。
2.在链表里如何发现循环链接?
3.编写反转字符串的程序,要求优化速度、优化空间。
4.给出洗牌的一个算法,并将洗好的牌存储在一个整形数组里。
5.写一个函数,检查字符是否是整数,如果是,返回其整数值。
(或者:怎样只用4行代码编写出一个从字符串到长整形的函数?)


98.第2组微软面试题
1.给出一个函数来输出一个字符串的所有排列。
2.请编写实现malloc()内存分配函数功能一样的代码。
3.给出一个函数来复制两个字符串A和B。字符串A的后几个字节和字符串B的前几个字节重叠。
4.怎样编写一个程序,把一个有序整数数组放到二叉树中?
5.怎样从顶部开始逐层打印二叉树结点数据?请编程。
6.怎样把一个链表掉个顺序(也就是反序,注意链表的边界条件并考虑空链表)?


99.第3组微软面试题
1.烧一根不均匀的绳,从头烧到尾总共需要1个小时。
现在有若干条材质相同的绳子,问如何用烧绳的方法来计时一个小时十五分钟呢?
2.你有一桶果冻,其中有黄色、绿色、红色三种,闭上眼睛抓取同种颜色的两个。
抓取多少个就可以确定你肯定有两个同一颜色的果冻?(5秒-1分钟)
3.如果你有无穷多的水,一个3公升的提捅,一个5公升的提捅,两只提捅形状上下都不均匀,
问你如何才能准确称出4公升的水?(40秒-3分钟)
一个岔路口分别通向诚实国和说谎国。
来了两个人,已知一个是诚实国的,另一个是说谎国的。
诚实国永远说实话,说谎国永远说谎话。现在你要去说谎国,
但不知道应该走哪条路,需要问这两个人。请问应该怎么问?(20秒-2分钟)


100.第4组微软面试题,挑战思维极限
1.12个球一个天平,现知道只有一个和其它的重量不同,问怎样称才能用三次就找到那个球。

13个呢?(注意此题并未说明那个球的重量是轻是重,所以需要仔细考虑)(5分钟-1小时)
2.在9个点上画10条直线,要求每条直线上至少有三个点?(3分钟-20分钟)
3.在一天的24小时之中,时钟的时针、分针和秒针完全重合在一起的时候有几次?
都分别是什么时间?你怎样算出来的?(5分钟-15分钟)

终结附加题:
微软面试题,挑战你的智商
==========
说明:如果你是第一次看到这种题,并且以前从来没有见过类似的题型,
并且能够在半个小时之内做出答案,说明你的智力超常..)
1.第一题 . 五个海盗抢到了100颗宝石,每一颗都一样大小和价值连城。他们决定这么分:
抽签决定自己的号码(1、2、3、4、5)

首先,由1号提出分配方案,然后大家表决,当且仅当超过半数的人同意时,
按照他的方案进行分配,否则将被扔进大海喂鲨鱼
如果1号死后,再由2号提出分配方案,然后剩下的4人进行表决,
当且仅当超过半数的人同意时,按照他的方案进行分配,否则将被扔入大海喂鲨鱼。

依此类推
条件:每个海盗都是很聪明的人,都能很理智地做出判断,从而做出选择。
问题:第一个海盗提出怎样的分配方案才能使自己的收益最大化?

2.一道关于飞机加油的问题,已知:
每个飞机只有一个油箱,
飞机之间可以相互加油(注意是相互,没有加油机)
一箱油可供一架飞机绕地球飞半圈,
问题:
为使至少一架飞机绕地球一圈回到起飞时的飞机场,至少需要出动几架飞机?
(所有飞机从同一机场起飞,而且必须安全返回机场,不允许中途降落,中间没有飞机场)
//欢迎,关注另外不同的更精彩的100题V0.2版,和此V0.1版的答案等后续内容。
本微软等面试100题系列V0.1版,完。

========================
关于本微软等公司数据结构+算法面试100题V0.1版
1.一切的详情,请参见My Blog:
http://blog.csdn.net/v_JULY_v
2.关于本微软等公司数据结构+算法面试100题系列V0.1版郑重声明

http://blog.csdn.net/v_JULY_v/archive/2010/12/02/6050133.aspx

3.所有的资源下载地址:
http://v_july_v.download.csdn.net/

4.本微软等100题系列V0.1版,永久维护地址:

http://topic.csdn.net/u/20101126/10/b4f12a00-6280-492f-b785-cb6835a63dc9.html

5.一切的详情,还是在本博客里。
本博客致力于数据结构之法、算法优化之道
不断更新、优选、搜集、整理微软等各大公司的精彩面试题。
欢迎,持久、继续关注本博客。
相信,另外不同、更具精彩的100题V0.2版,很快就能与大家见面。:D。

谢谢,大家。谢谢,各位。
谢谢。

=======================================================

欢迎,任何人,就以上任何内容,题目与答案思路,与我联系:
作者邮箱:
zhoulei0907@yahoo.cn


作者声明:
本人July对以上所有任何内容和资料享有版权,转载请注明作者本人July及出处。
向你的厚道致敬。谢谢。2010年12月05日。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
第一篇 面试 ................................................................................ 8 1.1. 简介 ............................................................................................................... 8 1.2. 面试集合(一) .......................................................................................... 8 1.2.1. 把二元查找树转变成排序的双向链表.................................................... 8 1.2.2. 下排每个数都是先前上排那十个数在下排出现的次数 ..........................11 1.2.3. 设计包含 min 函数的栈 ...................................................................... 14 1.2.4. 求子数组的最大和.............................................................................. 20 1.2.5. 在二元树找出和为某一值的所有路径 .............................................. 22 1.2.6. Top K 算法详细解析---百度面试 ......................................................... 29 1.2.7. 翻转句子单词的顺序....................................................................... 31 1.2.8. 判断整数序列是不是二元查找树的后序遍历结果 ................................ 33 1.2.9. 查找最小的 K 个元素-使用最大堆....................................................... 35 1.2.10. 求二叉树节点的最大距离................................................................ 37 1.3. 面试集合(二) ........................................................................................ 40 1.3.1. 求 1+2+…+n....................................................................................... 40 1.3.2. 输入一个单向链表,输出该链表倒数第 k 个结点............................. 44 1.3.3. 输入一个已经按升序排序过的数组和一个数字.................................... 46 1.3.4. 输入一颗二元查找树,将该树转换为它的镜像.................................... 48 1.3.5. 输入一颗二元树,从上往下按层打印树的每个结点,同一层按照从左往 右的顺序打印................................................................................................... 49 1.3.6. 在一个字符串找到第一个只出现一次的字符。如输入 abaccdeff,则输出 b 52 1.3.7. n 个数字(0,1,…,n-1)形成一个圆圈 .................................................. 53 1.3.8. 定义 Fibonacci 数列 ............................................................................ 58 1.3.9. 左移递减数列查找某一个数................................................................ 60 1.3.10. 对于一个整数矩阵,存在一种运算,对矩阵任意元素加一时,需要其相 邻(上下左右)某一个元素也加一 ................................................................... 63 1.4. 面试集合(三) ........................................................................................ 73 1.4.1. 递归和非递归俩种方法实现二叉树的前序遍历.................................... 73 1.4.2. 请修改 append 函数,利用这个函数实现............................................. 78 1.4.3. 有 n 个长为 m+1 的字符串 ................................................................ 82 1.4.4. n 支 队伍比赛 ..................................................................................... 84 1.4.5. 求一个矩阵最大的二维矩阵(元素和最大) ........................................ 86 1.4.6. 强大的和谐 ........................................................................................ 90 1.4.7. 通过交换 a,b 的元素,使[序列 a 元素的和]与[序列 b 元素的和]之间的差最小 94 1.4.8. 计算 1 到 N 的十进制数 1 的出现次数 ............................................. 97 1.4.9. 栈的 push、pop 序列[数据结构] .......................................................... 99 1.4.10. 统计整数二进制表示 1 的个数........................................................102 1.5. 面试集合(四) .......................................................................................104 1.5.1. 跳台阶问 .......................................................................................104 1.5.2. 左旋转字符串....................................................................................105 1.5.3. 在字符串找出连续最长的数字串 ....................................................109 1.5.4. 链表操作........................................................................................... 111 1.5.5. 有 4 张红色的牌和 4 张蓝色的牌........................................................ 115 1.5.6. 输入两个整数 n 和 m,从数列 1,2,3.......n 随意取几个数 ....... 116 1.5.7. 输入一个表示整数的字符串,把该字符串转换成整数并输出.............. 118 1.5.8. 给出一个数列,找出其最长的单调递减(或递增)子序列..............121 1.5.9. 四对括号可以有多少种匹配排列方式.................................................124 1.5.10. 输入一个正数 n,输出所有和为 n 连续正数序列 ................................125 1.6. 面试集合(五) .......................................................................................126 1.6.1. 输入一棵二元树的根结点,求该树的深度..........................................126 1.6.2. 输入一个字符串,打印出该字符串字符的所有排列 ........................128 1.6.3. 输入一个整数数组,调整数组数字的顺序,使得所有奇数位于数组的前半部分,所有偶数 位于数组的后半部分 ...........................................................130 1.6.4. 给定链表的头指针和一个结点指针,在 O(1)时间删除该结点 .............132 1.6.5. 输入一个链表的头结点,从尾到头反到来输出每个结点的值..............134 1.6.6. 用 C++设计一个不能被继承的类 .......................................................136 1.6.7. 给定链表的头指针和一个结点指针,在 O(1)时间删除该结点 .............138 1.6.8. 一个数组除了两个数字之外,其余数字均出现了两次.....................141 1.6.9. 两个单向链表,找出它们的第一个公共结点 ......................................142 1.6.10. 输入两个字符串,从第一字符串删除第二个字符串所有的字符 ...147 1.7. 面试集合(六) .......................................................................................148 1.7.1. 寻找丑数...........................................................................................148 1.7.2. 输入数字 n,按顺序输出从 1 最大的 n 位 10 进制数...........................152 1.7.3. 用递归颠倒一个栈.............................................................................156 1.7.4. 从扑克牌随机抽 5 张牌,判断是不是一个顺子 ...............................158 1.7.5. 把 n 个骰子扔在地上,所有骰子朝上一面的点数之和为 S ..................162 1.7.6. 排出的所有数字最小......................................................................165 1.7.7. 数组的旋转 .......................................................................................170 1.7.8. 给出一个函数来输出一个字符串的所有排列 ......................................171 1.7.9. 实现函数 double Power(double base,int exponent) .................................173 1.7.10. 更优的解法:....................................................................................175 1.7.11. 单列模式...........................................................................................176 1.8. 面试集合(七) .......................................................................................178 1.8.1. 找出该字符串对称的子字符串的最大长度 ......................................178 1.8.2. 数组有一个数字出现的次数超过了数组长度的一半,找出这个数字 180 1.8.3. 输入二叉树的两个结点,输出这两个结点在数最低的共同父结点 180 1.8.4. 复杂链表...........................................................................................187 1.8.5. 链表面试 .......................................................................................190 1.8.6. 链表和数字的区别在哪里 ..................................................................197 1.8.7. strstr()函数功能 .................................................................................198 1.8.8. 一个 int 数组,里面数据无任何限制,要求求出所有这样的数 a[i],其左 边的数都小于等于它,右边的数都大于等于它.................................................199 1.8.9. 一个文件,内含一千万行字符串,每个字符串在 1K 以内,要求找出所有 相反的串对,如 abc 和 cba。 ...........................................................................200 1.8.10. 给出一个文件,里面包含两个字段{url、size},即 url 为网址,size 为对应 网址访问的次数 ..............................................................................................205 1.9. 面试集合(八) .......................................................................................209 1.9.1. 给定一个存放整数的数组,重新排列数组使得数组左边为奇数,右边为偶数 209 1.9.2. 用 C 语言实现函数 void * memmove(void *dest,const void *src,size_t n) 210 1.9.3. 随机发生器 .......................................................................................212 1.9.4. 搜索引擎...........................................................................................212 1.9.5. 已知一个字符串,比如 asderwsde,寻找其的一个子字符串比如 sde 的个数,如果没有返回 0,有的话返回子字符串的个数 ..........................................216 1.9.6. 编写一个程序,把一个有序整数数组放到二叉树............................218 1.9.7. 大整数数相乘的问 .........................................................................220 1.9.8. 求最大连续递增数字串......................................................................221 1.9.9. 函数将字符串的字符'*'移到串的前部分 ..........................................222 1.9.10. 单链表,编程实现其逆转 ..................................................................223 1.10. 面试集合(九)....................................................................................225 1.10.1. 删除字符串的数字并压缩字符串 ....................................................225 1.10.2. 求两个串的第一个最长子串(神州数码以前试) ........................226 1.10.3. 不开辟用于交换数据的临时空间,如何完成字符串的逆序 .................228 1.10.4. 求随机数构成的数组找到长度大于=3 的最长的等差数列 ................228 1.10.5. 外排序 ..............................................................................................230 1.10.6. 用递归的方法判断整数组 a[N]是不是升序排列 ..................................232 1.10.7. N 个鸡蛋放到 M 个篮子,篮子不能为空 ........................................232 1.10.8. Hash .................................................................................................234 1.10.9. 如何迅速匹配兄弟字符串 ..................................................................242 1.10.10. 腾讯数组乘积赋值的问 .................................................................243 1.11. 面试集合(十) .......................................................................................244 1.11.1. 有一个整数数组,请求出两两之差绝对值最小的值............................244 1.11.2. 给出一个函数来合并两个字符串 A 和 B。字符串 A 的后几个字节和字符 串 B 的前几个字节重叠 ...................................................................................245 1.11.3. 编程实现两个正整数的除法(不能用除法操作符)............................250 1.11.4. 平面上 N 个点,没两个点都确定一条直线,求出斜率最大的那条直线所 通过的两个点..................................................................................................251 1.11.5. 字符串原地压缩 ................................................................................252 1.11.6. 一排 N(最大1M)个正整数+1 递增,乱序排列 ..............................253 1.11.7. 找出被重复的数字.............................................................................254 1.11.8. Hashtable 和 HashMap 的区别 ............................................................264 1.11.9. 用 1、2、2、3、4、5 这六个数字,写一个 main 函数,打印出所有不同的排列 268 1.11.10. 局部变量、全局变量和静态变量的含义 ............................................269 1.12. 面试集合(十一) ................................................................................272 1.12.1. 有两个双向循环链表 A,B,知道其头指针为:pHeadA,pHeadB,请写一 函数将两链表 data 值相同的结点删除...........................................................272 1.12.2. 找出两个字符串最大公共子字符串,如"abccade","dgcadde"的最大子串为"cad" 274 1.12.3. 把十进制数(long 型)分别以二进制和十六进制形式输出,不能使用 printf 系列 275 1.12.4. 40 亿个整数 ......................................................................................277 1.12.5. bitmap 减少 hash 算法所用空间 ..........................................................281 1.12.6. 定义一个类似函数的宏,宏运算的结果来表示大于和小于 .................285 1.12.7. 给定一个集合 A ................................................................................286 1.12.8. 已知一个函数 f 可以等概率的得到 1-5 间的随机数,问怎么等概率的得到 1-7 的随机数 ...................................................................................................289 1.12.9. 判断一个自然数是否是某个数的平方.................................................290 1.12.10. 一棵排序二叉树,令 f=(最大值+最小值)/2,设计一个算法,找出距离 f 值最近、大于 f 值的结点。复杂度如果是 O(n2)则不得分。 .............................291 1.12.11. strstr 和 strncmp 源码实现 .................................................................294 1.13. 面试集合(十二) ................................................................................295 1.13.1. 对于从 1 到 N 的连续整集合合,能划分成两个子集合,且保证每个集 合的数字和是相等...........................................................................................295 1.13.1. 对于从 1 到 N 的连续整集合合,能划分成两个子集合,且保证每个集 合的数字和是相 ..............................................................................................295 1.13.2. Topk .................................................................................................298 1.13.3. Collection ..........................................................................................301 1.13.4. 输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字 311 1.13.5. 求集合的所有子集的算法 ..................................................................314 1.13.6. 将一个数的偶数位 bit 和奇数位 bit 交换 .........................................318 1.13.7. 二分查找实现....................................................................................318 1.13.8. 集合合并...........................................................................................322 1.13.9. 把求子集运算转换为组合问 ...........................................................323 1.13.10. 算法设计..........................................................................................324 1.14. 面试集合(十三) ................................................................................327 1.14.1. 各种排序算法....................................................................................327 1.15. 面试集合(十四) ................................................................................393 1.15.1. 判断图里有环....................................................................................393 1.15.2. 整数的素数和分解问......................................................................422 1.15.3. 求两个或 N 个数的最大公约数(gcd)和最小公倍数(lcm)的较优算法 .....425 1.16. 面试集合(十五) ................................................................................426 1.16.1. ApplicationContext .............................................................................426 1.16.2. ApplicationContext 事件传播 ..............................................................431 1.16.3. mysql 有多种存储引擎.......................................................................433 1.16.4. 论 MySQL 何时使用索引,何时不使用索引 .......................................436 1.16.5. SQL 多表连接查询实现语句 .............................................................439 1.17. 面试集合(十六) ................................................................................442 1.17.1. 12 个高矮不同的人,排成两排,每排必须是从矮到高排列,而且第二排比对 应的第一排的人高,问排列方式有多少种 ..........................................................442 1.17.2. 毒酒..................................................................................................448 1.17.3. 用代码验证阿里巴巴的一道关于男女比例的面试............................448 1.17.4. 金币..................................................................................................451 1.17.5. 海盗..................................................................................................452 1.17.6. 1024..................................................................................................454 1.17.7. 最少零钱问 最少硬币问 .............................................................455 1.17.8. 石子合并...........................................................................................456 1.18. 面试集合(十七) ................................................................................460 1.18.1. 生产者-消费者模式 ...........................................................................460 1.18.2. 动态规划...........................................................................................466 1.18.3. 01 背包 .............................................................................................472 1.18.4. 贪心算法...........................................................................................477 1.18.5. 装箱问...........................................................................................482 1.19. 教你如何迅速秒杀掉:99%的海量数据处理面试 ...................................484
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值