百度2013研发工程师笔试卷B

1 面向对象的三个基本元素,五个基本原则

三个基本元素:

  • 封装
  • 继承
  • 多态

五个基本原则:

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

2 数据库以及线程发生死锁的原理及必要条件

产生死锁的原因主要是:

  • 因为系统资源不足。
  • 进程运行推进的顺序不合适。
  • 资源分配不当等。

产生死锁的四个必要条件:

  • 互斥条件:一个资源每次只能被一个进程使用。
  • 请求与保持条件:一个进程因请求资源而阻塞时,对已获得的资源保持不放。
  • 不剥夺条件:进程已获得的资源,在末使用完之前,不能强行剥夺。
  • 循环等待条件:若干进程之间形成一种头尾相接的循环等待资源关系。

3 有20个数组,每个数组有500个元素,并且是有序排列好的,现在在这20*500个数中找出排名前500的数。

TOP-K问题,用个数为K的最小堆归并处理

4 字符串左移

比如ABCDEFG,移3位变DEFGABC,要求空间复杂度O(1),时间复杂度O(n)。

void reverse(char *left, char *right)
{
    while (left < right)
    {
        char c = *left;
        *left++ = *right;
        *right-- = c;
    }
}
void* pszStringRotate(char *pszString, int nCharsRotate)
{
    int len = 0;
    char *p = pszString;
    while (*p++ != '\0')
    {
        len++;
    }
    reverse(pszString, pszString + len - 1);
    reverse(pszString, pszString + nCharsRotate);
    reverse(pszString + nCharsRotate + 1, pszString + len - 1);
    return pszString;
}

5 系统设计题

现在有一个手机,手机上的键盘上有这样的对应关系,2对应”abc”,3对应”def”…..手机里面有一个userlist用户列表,当我们输入942的时候出来拼音的对应可能是“xia”,“zha”,“xi”,“yi”等,当我们输入9264的时候出来是yang,可能是“样”,“杨”,“往”等,现在我们输入一个字符串数字,比如926等,要在电话簿userlist中查找出对应的用户名和电话号码并返回结果。

#include <iostream>
#include <cstring>
#include <cstdio>
using namespace std;
#define N 4
char c[][10] = {"","","ABC","DEF","GHI","JKL","MNO","PQRS","TUV","WXYZ"};//存储各个数字所能代表的字符
int number[N] = {2, 4 ,7, 9}; //存储电话号码
int total[10] = {0, 0, 3, 3, 3, 3, 3, 4, 3, 4}; //各个数组所能代表的字符总数
int answer[N]; //数字目前所代表的字符在其所能代表的字符集中的位置,初始为0
void Search(int *number, int n); //非递归的办法
void RecursiveSearch(int *number, int cur, char *ps, int n); //递归的办法
int main()
{
        Search(number, N);
//        char ps[N+1] = {0};
//        RecursiveSearch(number, 0, ps, N);
        return 0;
}
void Search(int *number, int n)
{
    while (1)
    {
        for (int i = 0; i < n; i++)
        {
            cout<<c[number[i]][answer[i]];
        }
        cout<<endl;
        int k = n - 1;
        while (k >= 0)
        {
            if (answer[k] < total[number[k]] - 1)
            {
                answer[k]++;
                break;
            }
            else
            {
                answer[k] = 0;
                k--;
            }
        }
        if (k < 0)
        {
            break;
        }
    }
}
//递归的解法: number为存储电话号码的数组,pos为当前处理的数字在number中的下标,初始为0
//ps为一外部数组,用于存放字母,n代表电话号码的长度(个数)
//此递归的方法好理解,比上面非递归的办法好写易懂
void RecursiveSearch(int *number, int pos, char *ps, int n)
{
    for (int i = 0; i < total[number[pos]]; i++)
    {
        ps[pos] = c[number[pos]][i];
        if (pos == n - 1)
        {
            cout<<ps<<endl;
        }
        else
        {
            RecursiveSearch(number, pos + 1, ps, n);
        }
    }
}

6 现在有100个灯泡,每个灯泡都是关着的,第一趟把所有的灯泡灯泡打开,第二趟把偶数位的灯泡制反(也就是开了的关掉,关了的打开),第三趟让第3,6,9….的灯泡制反…….第100趟让第100个灯泡制反,问经过一百趟以后有多少灯泡亮着。

答案:
1.对于每盏灯,拉动的次数是奇数时,灯就是亮着的,拉动的次数是偶数时,灯就是关着的。
2.每盏灯拉动的次数与它的编号所含约数的个数有关,它的编号有几个约数,这盏灯就被拉动几次。
3.1——100这100个数中有哪几个数,约数的个数是奇数。我们知道一个数的约数都是成对出现的,只有完全平方数约数的个数才是奇数个。 所以这100盏灯中有10盏灯是亮着的。 它们的编号分别是: 1、4、9、16、25、36、49、64、81、100。

7 windows内存管理的机制以及优缺点

分页存储管理基本思想:
用户程序的地址空间被划分成若干固定大小的区域,称为“页”,相应地,内存空间分成若干个物理块,页和块的大小相等。可将用户程序的任一页放在内存的任一块中,实现了离散分配。
分段存储管理基本思想:
将用户程序地址空间分成若干个大小不等的段,每段可以定义一组相对完整的逻辑信息。存储分配时,以段为单位,段与段在内存中可以不相邻接,也实现了离散分配。
段页式存储管理基本思想:
分页系统能有效地提高内存的利用率,而分段系统能反映程序的逻辑结构,便于段的共享与保护,将分页与分段两种存储方式结合起来,就形成了段页式存储管理方式。
在段页式存储管理系统中,作业的地址空间首先被分成若干个逻辑分段,每段都有自己的段号,然后再将每段分成若干个大小相等的页。对于主存空间也分成大小相等的页,主存的分配以页为单位。
段页式系统中,作业的地址结构包含三部分的内容:段号 页号 页内位移量
程序员按照分段系统的地址结构将地址分为段号与段内位移量,地址变换机构将段内位移量分解为页号和页内位移量。
为实现段页式存储管理,系统应为每个进程设置一个段表,包括每段的段号,该段的页表始址和页表长度。每个段有自己的页表,记录段中的每一页的页号和存放在主存中的物理块号。

时间: 2024-10-22 09:54:39

百度2013研发工程师笔试卷B的相关文章

[历年IT笔试题]2014百度校园招聘-研发工程师笔试题(济南站)

一,简答题(30分) 1,当前计算机系统一般会采用层次结构存储数据,请介绍下典型计算机存储系统一般分为哪几个层次,为什么采用分层存储数据能有效提高程序的执行效率?(10分) 所谓存储系统的层次结构,就是把各种不同存储容量.存取速度和价格的存储器按层次结构组成多层存储器,并通过管理软件和辅助硬件有机组合成统一的整体,使所存放的程序和数据按层次分布在各种存储器中.目前,在计算机系统中通常采用三级层次结构来构成存储系统,主要由高速缓冲存储器Cache.主存储器和辅助存储器组成.存储系统多级层次结构中,

消息称百度正研发百度中文输入法的PC版本

消息人士独家透露,百度正在研发百度中文输入法的PC版本.来自百度官方网站上的招聘信息进一步证实了该消息. 2009年11月,百度正式推出"百度手机输入法"移动客户端,百度客户端业务部总监王啸也曾公开表示,百度暂不考虑涉足PC端输入法市场.然而就在短短 的3周时间,也就是12月16日,百度在日本推出了PC版输入法,中国市场却一直没有推出中文输入法的PC版本. 输入法虽然是轻量级的应用,但越来越多互联网大公司正加入此领域的争夺.目前被用户下载和使用最多的PC版本的输入法包括QQ输入法.搜狗

百度上海研发中心启动成立来最大招聘规模将翻三倍

挖贝网7月15日消息,今天,百度上海研发中心宣布启动成立以来的最大规模招聘,在年内引入200多名优秀的技术研发精英加盟.这也意味着,在此次招聘结束后,百度上海研发中心的研发规模将较目前扩大三倍有余. 百度上海研发中心成立于2008年12月,是百度最重要的技术研发机构之一,承担着包括搜索技术国际化支持等百度若干重要项目的研发工作.资料显示,本次百度上海研发中心招聘开放的职位,除了常规的搜索引擎研发工程师.JAVA高级研发工程师.测试开发工程师.Web前端研发工程师等职位外,还包括若干经济学者的招募

清华学生借鉴百度技术研发手机“框计算”

据百度方面介绍,目前清华学子们研发出的手机框计算产品,索引了近万条校内http://www.aliyun.com/zixun/aggregation/10227.html">生活信息,并在清华部分师生之中展开了小规模应用. 据介绍,"框计算" 理念由百度CEO李彦宏在2009年百度技术创新大会上首度提出,旨在直接根据用户需求为其提供基于互联网的一站式服务,是一种简单可依赖的互联网需求交互模式. 自去年起,百度和清华联合开设了搜索引擎课程,由清华教授及百度资深技术工程师共

前百度产品研发总监李湛加盟游族任职CTO

摘要: 李湛 11月19日消息,据游族网络官方信息,原 百度 产品研发总监.复合搜索部副总监李湛日前正式加盟游族网络,担任CTO(首席技术官)职位.李湛将负责游族的技术和业务创新工作,带 李湛 11月19日消息,据游族网络官方信息,原 百度 产品研发总监.复合搜索部副总监李湛日前正式加盟游族网络,担任CTO(首席技术官)职位.李湛将负责游族的技术和业务创新工作,带领技术团队,夯实技术基础架构.提升用户体验. 李湛2003年至2014年间任职于百度,先后任工程师.经理.总监等,曾长期负责百度搜索推

百度秘密研发“影子导航” 已申请技术专利

缺乏方向感的用户可能常常遇到这种困惑:即便看手机导航,你也不清楚自己的方位.也许走了很久,才发现走错了方向.百度公司近日申请的一项名为"导航用户朝向确定方法及装置"的http://www.aliyun.com/zixun/aggregation/17705.html">技术专利,或许可以帮助"路痴"朋友解决麻烦.利用这一技术,用户通过比较现实影子和地图上的"影子",就可以判断出正确的方向. 记者在国家知识产权局专利检索系统中查询发

尝试做“无线研发工程师”有感

开始着手写这个文章的时候,心生感概,好像终于在业务上阶段性的理顺了一些事情和代码.可以挤出那么一点点时间写写自己这一两个月以来的感受了. 前段时间一直在业务压力中,熟悉代码,改代码,堆代码.甚至都没来得及好好的想想业务的加分项,包括可做的更有价值的事情. 原因就是因为组织架构的调整,我们从前端职能走出去,接手了一整块业务.从前到后,从客户端到服务端. 而我个人作为团队的领跑者,作为从"前端"走出去的同学,一定是要先行在跨端跨栈这件事情上的.以便给团队同学铺好路,让大家都能更轻更快的过度

学生党如何拿到阿里技术offer: 《2016阿里巴巴校招内推offer之Java研发工程师(成功)》

大学里有这样一句话"现在流的泪,都是当初选专业是脑子进的水",从见闻中了解很多中学非常优秀的同学因为选择了自己不喜欢不感冒的专业,很多人不懂得为自己寻找方向,而是继续延续应试教育下的学习方式,这样,他们的学习便成为了"面向考试"的学习,当他们走出大学校门,往往会发现,自己出了成绩单上的几个数字之外收获甚少.   但其实学习的主动权就在自己手中,你不喜欢自己的专业,但是你可以为自己选择未来的路.在计算机互联网行业,不是科班出身但是取得辉煌成就的人大有人在,问及为什么不

资深后台研发工程师(转)

资深后台研发工程师 岗位职责: 1.负责搭建平台网络架构及技术架构: 2.把握平台开发方向和技术路线,解决关键技术问题: 3.负责与战略客户.合作伙伴的方案讨论,技术交流以及开发管理: 4.负责参与项目启动.项目计划.项目选型.项目实施.项目验收及项目内部总结等相关工作: 5.参与公司其它技术问题讨论与决策: 6.公司交办的其他事项. 任职要求: 1.5年以上互联网产品研发经验: 2.精通J2EE相关技术,编程基础扎实,熟悉io.多线程.集合等基础框架: 3.熟悉Spring, Spring M