百度2013校园招聘笔试题(含自己整理的答案)

来源:互联网 发布:培训数据库开发 编辑:程序博客网 时间:2024/05/03 21:59
一:简答题(30)
1:数据库以及线程发生死锁的原理及必要条件,如何避免死锁
答:
产生死锁的原因主要是:
(1) 因为系统资源不足。
(2) 进程运行推进的顺序不合适。
(3) 资源分配不当等。
产生死锁的四个必要条件
(1)互斥条件:一个资源每次只能被一个进程使用。
(2)请求与保持条件:一个进程因请求资源而阻塞时,对已获得的资源保持不放。
(3)不剥夺条件:进程已获得的资源,在末使用完之前,不能强行剥夺。
(4)循环等待条件:若干进程之间形成一种头尾相接的循环等待资源关系。

避免死锁:
死锁的预防是通过破坏产生条件来阻止死锁的产生,但这种方法破坏了系统的并行性和并发性。
死锁产生的前三个条件是死锁产生的必要条件,也就是说要产生死锁必须具备的条件,而不是存在这3个条件就一定产生死锁,那么只要在逻辑上回避了第四个条件就可以避免死锁。
避免死锁采用的是允许前三个条件存在,但通过合理的资源分配算法来确保永远不会形成环形等待的封闭进程链,从而避免死锁。该方法支持多个进程的并行执行,为了避免死锁,系统动态的确定是否分配一个资源给请求的进程。
预防死锁:具体的做法是破坏产生死锁的四个必要条件之一

2:面向对象的三个基本元素,五个基本原则
答:
三个基本元素:
  • 封装
  • 继承
  • 多态
五个基本原则:
  • 单一职责原则(Single-Resposibility Principle):一个类,最好只做一件事,只有一个引起它的变化。单一职责原则可以看做是低耦合、高内聚在面向对象原则上的引申,将职责定义为引起变化的原因,以提高内聚性来减少引起变化的原因。
  • 开放封闭原则(Open-Closed principle):软件实体应该是可扩展的,而不可修改的。也就是,对扩展开放,对修改封闭的
  • Liskov替换原则(Liskov-Substituion Principle):子类必须能够替换其基类。这一思想体现为对继承机制的约束规范,只有子类能够替换基类时,才能保证系统在运行期内识别子类,这是保证继承复用的基础。
  • 依赖倒置原则(Dependecy-Inversion Principle):依赖于抽象。具体而言就是高层模块不依赖于底层模块,二者都同依赖于抽象;抽象不依赖于具体,具体依赖于抽象。
  • 接口隔离原则(Interface-Segregation Principle):使用多个小的专门的接口,而不要使用一个大的总接口。
3:windows内存管理的机制以及优缺点
答:

 分页存储管理基本思想:

用户程序的地址空间被划分成若干固定大小的区域,称为“页”,相应地,内存空间分成若干个物理块,页和块的大小相等。可将用户程序的任一页放在内存的任一块中,实现了离散分配。

分段存储管理基本思想:

将用户程序地址空间分成若干个大小不等的段,每段可以定义一组相对完整的逻辑信息。存储分配时,以段为单位,段与段在内存中可以不相邻接,也实现了离散分配。

段页式存储管理基本思想:

分页系统能有效地提高内存的利用率,而分段系统能反映程序的逻辑结构,便于段的共享与保护,将分页与分段两种存储方式结合起来,就形成了段页式存储管理方式。

在段页式存储管理系统中,作业的地址空间首先被分成若干个逻辑分段,每段都有自己的段号,然后再将每段分成若干个大小相等的页。对于主存空间也分成大小相等的页,主存的分配以页为单位。

段页式系统中,作业的地址结构包含三部分的内容:段号      页号       页内位移量

程序员按照分段系统的地址结构将地址分为段号与段内位移量,地址变换机构将段内位移量分解为页号和页内位移量。

为实现段页式存储管理,系统应为每个进程设置一个段表,包括每段的段号,该段的页表始址和页表长度。每个段有自己的页表,记录段中的每一页的页号和存放在主存中的物理块号。


二:程序设计题(40)
 
1:公司里面有1001个员工,现在要在公司里面找到最好的羽毛球选手,也就是第一名,每个人都必须参赛,问至少要比赛多少次才能够找到最好的羽毛球员工。
答:两两比赛,分成500组剩下一人,类似于归并排序的方式,比出冠军后,让冠军之间再比,主要是要想想多余的那一个选手如何处理,必然要在第一次决出冠军后加入比赛组。
 
2:现在有100个灯泡,每个灯泡都是关着的,第一趟把所有的灯泡灯泡打开,第二趟把偶数位的灯泡制反(也就是开了的关掉,关了的打开),第三趟让第3,6,9....的灯泡制反.......第100趟让第100个灯泡制反,问经过一百趟以后有多少灯泡亮着
答:

1.对于每盏灯,拉动的次数是奇数时,灯就是亮着的,拉动的次数是偶数时,灯就是关着的。
2.每盏灯拉动的次数与它的编号所含约数的个数有关,它的编号有几个约数,这盏灯就被拉动几次。
3.1——100这100个数中有哪几个数,约数的个数是奇数。我们知道一个数的约数都是成对出现的,只有完全平方数约数的个数才是奇数个。

所以这100盏灯中有10盏灯是亮着的。
它们的编号分别是: 1、4、9、16、25、36、49、64、81、100。

 
3:有20个数组,每个数组有500个元素,并且是有序排列好的,现在在这20*500个数中找出排名前500的数
答:TOP-K问题,用个数为K的最小堆来解决

4. 字符串左移,void *pszStringRotate(char *pszString, intnCharsRotate),比如ABCDEFG,移3位变DEFGABC,要求空间复杂度O1),时间复杂度On
现在有一个手机,手机上的键盘上有这样的对应关系,2对应"abc",3对应"def".....手机里面有一个userlist用户列表,当我们输入942的时候出来拼音的对应可能是“xia”,“zha”,“xi”,“yi”等,当我们输入9264的时候出来是yang,可能是“样”,“杨”,“往”等,现在我们输入一个字符串数字,比如926等,要在电话簿userlist中查找出对应的用户名和电话号码并返回结果。
[cpp] view plaincopyprint?
  1. C++语言: 电话号码对应的英语单词(注意此题的非递归做法)  
  2. #include <iostream>  
  3. #include <cstdlib>  
  4. #define N 4 //电话号码个数  
  5.   
  6. using namespace std;  
  7.   
  8. char c[][10] = {"","","ABC","DEF","GHI","JKL","MNO","PQRS","TUV","WXYZ"};//存储各个数字所能代表的字符  
  9. int number[N] = {2, 4 ,7, 9}; //存储电话号码  
  10. int total[10] = {0, 0, 3, 3, 3, 3, 3, 4, 3, 4}; //各个数组所能代表的字符总数  
  11. int answer[N]; //数字目前所代表的字符在其所能代表的字符集中的位置,初始为0  
  12.   
  13. void Search(int *number, int n); //非递归的办法  
  14. void RecursiveSearch(int *number, int cur, char *ps, int n); //递归的办法  
[cpp] view plaincopyprint?
  1. int main()  
  2. {  
  3.         //Search(number, N);  
  4.         char ps[N+1] = {0};  
  5.         RecursiveSearch(number, 0, ps, N);  
  6.         return 0;  
  7. }  
  8.   
  9.   
  10. void Search(int *number, int n)  
  11. {  
  12.         int i;  
  13.         while(1)  
  14.         {  
  15.                 for(i=0; i<n; ++i)  
  16.                         printf("%c", c[number[i]][answer[i]]);  
  17.                 printf("\n");  
  18.                 int k = n-1;    //用k和while循环来解决扩展性问题,模拟了递归  
  19.                 while(k >= 0)  
  20.                 {  
  21.                         if(answer[k] < total[number[k]]-1)  
  22.                         {  
  23.                                 ++answer[k];  
  24.                                 break;  
  25.                         }  
  26.                         else  
  27.                         {  
  28.                                 answer[k] = 0;  
  29.                                 --k;  
  30.                         }  
  31.                 }  
  32.                 if(k < 0)  
  33.                         break;  
  34.         }  
  35. }  
  36.   
  37.   
  38. /*递归的解法: number为存储电话号码的数组,pos为当前处理的数字在number中的下标,初始为0 
  39. *ps为一外部数组,用于存放字母,n代表电话号码的长度(个数) 
  40. * 此递归的方法好理解,比上面非递归的办法好写易懂 
  41. * */  
  42. void RecursiveSearch(int *number, int pos, char *ps, int n)  
  43. {  
  44.         int i;  
  45.         for(i=0; i<total[number[pos]]; ++i)  
  46.         {  
  47.                 ps[pos] = c[number[pos]][i];  
  48.                 if(pos == n-1)  
  49.                         cout<<ps<<endl;  
  50.                 else  
  51.                         RecursiveSearch(number, pos+1, ps, n);  
  52.         }  

开发测试试题

1、Java如何体现面向对象思想?

封装、继承、多态?

2、Java如何实现多态?

[java] view plaincopyprint?
01.class A
02.{
03. void m();
04.}
05.class B extends A
06.{
07. void m();
08.}
09.A a = new B();
10.a.m(); //这里调用的是B的m方法
3、实现压栈操作?(给了个栈结构,具体的记不住了)

二、

1、写一函数,实现查找某一字符串中子串的个数,例如String中i的个数为1 [java] view plaincopyprint?
01.public int calSubString(String s, String sub) {
02. int n = 0;
03. char[] c = s.toCharArray();
04. for (char e : c) {
05. if (String.valueOf(e).equals(sub)) { n++; }
06. }
07. return n;
08.}
2、非递归实现二叉树的后序遍历,要求时间复杂度和空间复杂度都是O(n)

3、链表,每个节点有两个指针,第一个指针指向后一个节点,第二个指针指向后一个的后一个节点,设计函数实现删除所有值为M的节点

三、

基于手机平台设计Push系统,包括手机端和Push Server端。这套Push系统是一个基础服务系统,不包括具体业务逻辑,是一个开放系统,开放给第三方应用开发者使用。请基于手机系统的一些特性,来设计这套Push系统。

1) 描述手机端部分设计时,需要考虑的关键性能指标有哪些

2) 画出手机端程序结构图

3) 画出第三方程序使用这套系统时所涉及到的相关部分系统结构图

4) 你觉得基于这套系统能够开发一个什么样的第三方程序,并举一个例子

开发测试(北京)

1、用简单语句描述数据库操作的步骤

tcp/ip四层结构

什么是MVC结构,并描述各层结构的作用

1、字母a-z,数字0-9,现需要其中任意3个作为密码,请输出所有可能组合。(伪码\C\C++\JAVA)(10分)

2、实现字符串反转函数(10分)

3、给定字符函数a、插入 b、删除 c、替换
例如字符串A=acegf,字符串B=adef,最少需要2步操作将A转换为B,即第一步将c替换为d,第二步将g删除;
(1)请问将字符串A=gumbo转换为字符串B=gambol,最少需要几步操作,列出如何操作(2分)
(2)任意字符串A和字符串B,如何计算最小操作次数,计算思路,并给出递归公式(3分)
(3)实现代码(注意代码风格与效率)(15分)

快排

三、系统设计题(30分)
RSA SecurID安全系统
应用场景:这是一种用户登录验证手段,例如银行登录系统,这个设备显示6位数字,每60秒变一次,再经过服务器认证,通过则允许登录。问How to design this system?
1)系统设计思路?服务器端为何能有效认证动态密码的正确性?
2)如果是千万量级永固,给出系统设计图示或说明,要求子功能模块划分清晰,给出关键的数据结构或数据库表结构。
考虑用户量级的影响和扩展性,用户密码的随机性等,如果设计系统以支持这几个因素.
3)系统算法升级时,服务器端和设备端可能都要有所修改,如何设计系统,能够使得升级过程(包括可能的设备替换或重设)尽量平滑?

三、设计是有100w学生数据,包含姓名|学生描述,比如,李四,篮球爱好者;姓名不超过4汉字,描述不超过50汉字,要求
1.查询名字,能快速得到所有信息
2.查询单字,比如“篮”,可得出包含此字的所有描述及其对应的学生姓名
3.不能使用现有的数据库技术  
用hash吗,具体应该怎么做啊?求大神指点

1,字典树,B树,哈希
: 2,倒排索引

http://stblog.baidu-tech.com/?p=418

原创粉丝点击