百度技术研发笔试题目

上传人:冷*** 文档编号:17844019 上传时间:2020-12-07 格式:DOCX 页数:21 大小:27.18KB
收藏 版权申诉 举报 下载
百度技术研发笔试题目_第1页
第1页 / 共21页
百度技术研发笔试题目_第2页
第2页 / 共21页
百度技术研发笔试题目_第3页
第3页 / 共21页
资源描述:

《百度技术研发笔试题目》由会员分享,可在线阅读,更多相关《百度技术研发笔试题目(21页珍藏版)》请在装配图网上搜索。

1、百度技术研发笔试题目百度技术研发笔试题目想要应聘百度技术研发员一职的求职者,不妨先练练如下分享的相关笔试题,提前热下身。有一根27厘米的细木杆,在第3厘米、7厘米、11厘米、17厘米、23厘米这五个位置上各有一只蚂蚁。木杆很细,不能同时通过一只蚂蚁。开始时,蚂蚁的头朝左还是朝右是任意的,它们只会朝前走或调头,但不会后退。当任意两只蚂蚁碰头时,两只蚂蚁会同时调头朝反方向走。假设蚂蚁们每秒钟可以走一厘米的距离。编写程序,求所有蚂蚁都离开木杆的最小时间和最大时间。分析:题目中的蚂蚁只可能相遇在整数点,不可以相遇在其它点,比如3.5cm处之类的,也就是可以让每只蚂蚁走1秒,然后查看是否有相遇的即可.这

2、样我的程序实现思路就是,初始化5只蚂蚁,让每只蚂蚁走1秒,然后看是否有相遇的,如果有则做相应处理.当每只蚂蚁都走出木杆时,我就记录当前时间.这样就可以得到当前状态情况下,需要多久可以走出木杆,然后遍历所有状态则可以得到所有可能.*/packagebaidu;publicclassAnt/*step表示蚂蚁每一个单位时间所走的长度*/privatefinalstaticintstep=1;/*position表示蚂蚁所处的初始位置*/privateintposition;/*direction表示蚂蚁的前进方向,如果为1表示向27厘米的方向走,如果为-1,则表示往0的方向走。*/privatei

3、ntdirection=1;/*此函数运行一次,表示蚂蚁前进一个单位时间,如果已经走下木杆则会抛出异常*/publicvoidwalk()if(isOut()thrownewRuntimeException(theantisout);position=position+this.direction*step;/*检查蚂蚁是否已经走出木杆,如果走出返回true*/publicbooleanisOut()returnposition=27;/*检查此蚂蚁是否已经遇到另外一只蚂蚁*paramant*return如果遇到返回true*/publicbooleanisEncounter(Antant)r

4、eturnant.position=this.position;/*改变蚂蚁的前进方向*/publicvoidchangeDistation()direction=-1*direction;/*构造函数,设置蚂蚁的初始前进方向,和初始位置*paramposition*paramdirection*/publicAnt(intposition,intdirection)this.position=position;if(direction!=1)this.direction=-1;/方向设置初始位置,比如为0时,也将其设置为1.这样可以方便后面的处理elsethis.direction=1;/p

5、ackagebaidu;publicclassControllerpublicstaticvoidmain(Stringargs)inttime=0;for(inti=0;iAntantArray=getAntList(getPoistions(),getDirections(i);while(!isAllOut(antArray)for(Antant:antArray)if(!ant.isOut()ant.walk();time+;/查看是否有已经相遇的Ant,如果有则更改其前进方向dealEncounter(antArray);System.out.println(time);/将时间归0

6、,这样可以重新设置条件,再次得到全部走完所需要的时间.time=0;/*这个函数的算法很乱,但暂时能解决问题*paramlist*/publicstaticvoiddealEncounter(AntantArray)intnum_ant=antArray.length;for(intj=0;jfor(intk=j+1;kif(antArrayj.isEncounter(antArrayk)antArrayj.changeDistation();antArrayk.changeDistation();/*因为有5只Ant,所以组合之后有32种组合.刚好用5位二进制来表示,如果为0则表示Ant往0

7、的方向走如果为1,则表示往27的方向走*注:在通过Ant的构造函数设置初始值时,通过过滤把0修改成了-1.*/publicstaticintgetDirections(intseed)intresult=newint5;result0=seed%2;result1=seed/2%2;result2=seed/4%2;result3=seed/8%2;result4=seed/16%2;System.out.println(directionsis+result0+|+result1+|+result2+|+result3+|+result4);returnresult;/*批量设置Ant的初始

8、位置,这样设置不是十分必要,可以直接在代码中设置*return*/publicstaticintgetPoistions()returnnewint3,7,11,17,23;/*取得设置好初始值的5只Ant*parampositions*paramdirections*return*/publicstaticAntgetAntList(intpositions,intdirections)Antant3=newAnt(positions0,directions0);Antant7=newAnt(positions1,directions1);Antant11=newAnt(positions2

9、,directions2);Antant17=newAnt(positions3,directions3);Antant23=newAnt(positions4,directions4);returnnewAntant3,ant7,ant11,ant17,ant23;/*判断是否所有的Ant都已经走出了木杆,也就是设置退出条件*paramantArray*return*/publicstaticbooleanisAllOut(AntantArray)for(Antant:antArray)if(ant.isOut()=false)returnfalse;returntrue;编程:用C语言实现

10、一个revert函数,它的功能是将输入的字符串在原串上倒序后返回。2编程:用C语言实现函数void*memmove(void*dest,constvoid*src,size_tn)。memmove函数的功能是拷贝src所指的内存内容前n个字节到dest所指的地址上。3英文拼写纠错:在用户输入英文单词时,经常发生错误,我们需要对其进行纠错。假设已经有一个包含了正确英文单词的词典,请你设计一个拼写纠错的程序。(1)请描述你解决这个问题的思路;(2)请给出主要的处理流程,算法,以及算法的复杂度;(3)请描述可能的改进(改进的方向如效果,性能等等,这是一个开放问题)。4寻找热门查询:搜索引擎会通过日志

11、文件把用户每次检索使用的所有检索串都记录下来,每个查询串的长度为1-255字节。假设目前有一千万个记录,这些查询串的重复度比较高,虽然总数是1千万,但如果除去重复后,不超过3百万个。一个查询串的重复度越高,说明查询它的用户越多,也就是越热门。请你统计最热门的10个查询串,要求使用的内存不能超过1G。(1)请描述你解决这个问题的思路;(2)请给出主要的处理流程,算法,以及算法的复杂度。5集合合并:给定一个字符串的集合,格式如:aaabbbccc,bbbddd,eeefff,ggg,dddhhh要求将其中交集不为空的集合合并,要求合并完成后的集合之间无交集,例如上例应输出aaabbbcccdddh

12、hh,eeefff,ggg(1)请描述你解决这个问题的思路;(2)请给出主要的处理流程,算法,以及算法的复杂度(3)请描述可能的改进(改进的方向如效果,性能等等,这是一个开放问题)。/11题char*revert(char*str)intn=strlen(str);inti=0;charc;for(i=0;ic=str;str=strn-i;strn-i=c;returnstr;/2题void*memmove(void*dest,constvoid*src,size_tn)assert(dest!=0)&&(src!=0);char*temp=(char*)dest;char*

13、ss=(char*)src;inti=0;for(;i*temp+=*ss+;returntemp;/3题(1)思路:字典以字母键树组织,在用户输入同时匹配(2)流程:每输入一个字母:沿字典树向下一层,a)若可以顺利下行,则继续至结束,给出结果;b)若该处不能匹配,纠错处理,给出拼写建议,继续至a);算法:1.在字典中查找单词字典采用27叉树组织,每个节点对应一个字母,查找就是一个字母一个字母匹配.算法时间就是单词的长度k.2.纠错算法情况:当输入的最后一个字母不能匹配时就提示出错,简化出错处理,动态提示可能处理方法:(a)当前字母前缺少了一个字母:搜索树上两层到当前的匹配作为建议;(b)当前

14、字母拼写错误:当前字母的键盘相邻作为提示;(只是简单的描述,可以有更多的)根据分析字典特征和用户单词已输入部分选择(a),(b)处理复杂性分析:影响算法的效率主要是字典的实现与纠错处理(a)字典的实现已有成熟的算法,改进不大,也不会成为瓶颈;(b)纠错策略要简单有效,如前述情况,是线性复杂度;(3)改进策略选择最是重要,可以采用统计学习的方法改进。/4题(1)思路:用哈希做(2)首先逐次读入查询串,算哈希值,保存在内存数组中,同时统计频度(注意值与日志项对应关系)选出前十的频度,取出对应的日志串,简单不过了。哈希的设计是关键。/5题(1)思路:先将集合按照大小排列后,优先考虑小的集合是否与大的

15、集合有交集。有就合并,如果小集合与所有其他集合都没有交集,则独立。独立的集合在下一轮的比较中不用考虑。这样就可以尽量减少字符串的比较次数。当所有集合都独立的时候,就终止。(2)处理流程:1.将集合按照大小排序,组成集合合并待处理列表2.选择最小的集合,找出与之有交集的集合,如果有,合并之;如果无,则与其它集合是独立集合,从待处理列表中删除。3.重复直到待处理列表为空算法:1。将集合按照大小从小到大排序,组成待处理的集合列表。2。取出待处理集合列表中最小的集合,对于集合的每个元素,依次在其他集合中搜索是否有此元素存在:1若存在,则将此小集合与大集合合并,并根据大小插入对应的位置。转3。2若不存在

16、,则在该集合中取下一个元素。如果无下一个元素,即所有元素都不存在于其他集合。则表明此集合独立,从待处理集合列表中删除。并加入结果集合列表。转3。3。如果待处理集合列表不为空,转2。如果待处理集合列表为空,成功退出,则结果集合列表就是最终的输出。算法复杂度分析:假设集合的个数为n,最大的集合元素为m排序的时间复杂度可以达到n*log(n)然后对于元素在其他集合中查找,最坏情况下为(n-1)*m查找一个集合是否与其他集合有交集的最坏情况是m*m*(n-1)合并的时间复杂度不会超过查找集合有交集的最坏情况。所以最终最坏时间复杂度为O(m*m*n*n)需要说明的是:此算法的平均时间复杂度会很低,因为无论是查找还是合并,都是处于最坏情况的概率很小,而且排序后优先用最小集合作为判断是否独立的对象,优先与最大的集合进行比较,这些都最大的回避了最坏情况。(3)可能的改进:首先可以实现将每个集合里面的字符串按照字典序进行排列,这样就可以将查找以及合并的效率增高。另外,可能采取恰当的数据结构也可以将查找以及合并等操作的效率得到提高。http:/

展开阅读全文
温馨提示:
1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
2: 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
3.本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
关于我们 - 网站声明 - 网站地图 - 资源地图 - 友情链接 - 网站客服 - 联系我们

copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!