成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

百度技術研發筆試題目

企業動態
百度技術研發筆試題目,大家看看吧!

有一根27厘米的細木桿,在第3厘米、7厘米、11厘米、17厘米、23厘米這五個位置上各有一只螞蟻。木桿很細,不能同時通過一只螞蟻。開始時,螞蟻的頭朝左還是朝右是任意的,它們只會朝前走或調頭,但不會后退。當任意兩只螞蟻碰頭時,兩只螞蟻會同時調頭朝反方向走。假設螞蟻們每秒鐘可以走一厘米的距離。

編寫程序,求所有螞蟻都離開木桿的最小時間和***時間。

分析:題目中的螞蟻只可能相遇在整數點,不可以相遇在其它點,比如3.5cm處之類的,也就是可以讓每只螞蟻走1秒,然后查看是否有相遇的即可.這樣我的程序實現思路就是,初始化5只螞蟻,讓每只螞蟻走1秒,然后看是否有相遇的,如果有則做相應處理.當每只螞蟻都走出木桿時,我就記錄當前時間.這樣就可以得到當前狀態情況下,需要多久可以走出木桿,然后遍歷所有狀態則可以得到所有可能.

*/

packagebaidu;

publicclassAnt{

/*

*step表示螞蟻每一個單位時間所走的長度

*/

privatefinalstaticintstep=1;

/*

*position表示螞蟻所處的初始位置

*/

privateintposition;

/*

*direction表示螞蟻的前進方向,如果為1表示向27厘米的方向走,如果為-1,則表示往0的方向走。

*/

privateintdirection=1;

/*

*此函數運行一次,表示螞蟻前進一個單位時間,如果已經走下木桿則會拋出異常

*/

publicvoidwalk(){

if(isOut()){

thrownewRuntimeException("theantisout");

}

position=position+this.direction*step;

};

/**

*檢查螞蟻是否已經走出木桿,如果走出返回true

*

*/

publicbooleanisOut(){

returnposition<=0||position>=27;

}

/**

*檢查此螞蟻是否已經遇到另外一只螞蟻

*@paramant

*@return如果遇到返回true

*/

publicbooleanisEncounter(Antant){

returnant.position==this.position;

}

/**

*改變螞蟻的前進方向

*/

publicvoidchangeDistation(){

direction=-1*direction;

}

/**

*構造函數,設置螞蟻的初始前進方向,和初始位置

*@paramposition

*@paramdirection

*/

publicAnt(intposition,intdirection){

this.position=position;

if(direction!=1){

this.direction=-1;//方向設置初始位置,比如為0時,也將其設置為1.這樣可以方便后面的處理

}else{

this.direction=1;

}

}

}

 

/////////////////////////////////////////////////////////

packagebaidu;

publicclassController{

publicstaticvoidmain(String[]args){

inttime=0;

for(inti=0;i<32;i++){

Ant[]antArray=getAntList(getPoistions(),getDirections(i));

while(!isAllOut(antArray)){

for(Antant:antArray){

if(!ant.isOut()){

ant.walk();

}

}

time++;

//查看是否有已經相遇的Ant,如果有則更改其前進方向

dealEncounter(antArray);

}

System.out.println(time);

//將時間歸0,這樣可以重新設置條件,再次得到全部走完所需要的時間.

time=0;

}

}

/**

*這個函數的算法很亂,但暫時能解決問題

*

*@paramlist

*/

publicstaticvoiddealEncounter(Ant[]antArray){

intnum_ant=antArray.length;

for(intj=0;j

for(intk=j+1;k

if(antArray[j].isEncounter(antArray[k])){

antArray[j].changeDistation();

antArray[k].changeDistation();

}

}

}

}

/**

*因為有5只Ant,所以組合之后有32種組合.剛好用5位二進制來表示,如果為0則表示Ant往0的方向走如果為1,則表示往27的方向走

*

*注:在通過Ant的構造函數設置初始值時,通過過濾把0修改成了-1.

*/

publicstaticint[]getDirections(intseed){

intresult[]=newint[5];

result[0]=seed%2;

result[1]=seed/2%2;

result[2]=seed/4%2;

result[3]=seed/8%2;

result[4]=seed/16%2;

System.out.println("directionsis"+result[0]+"|"+result[1]+"|"

+result[2]+"|"+result[3]+"|"+result[4]);

returnresult;

}

/**

*批量設置Ant的初始位置,這樣設置不是十分必要,可以直接在代碼中設置

*

*@return

*/

publicstaticint[]getPoistions(){

returnnewint[]{3,7,11,17,23};

}

/**

*取得設置好初始值的5只Ant

*

*@parampositions

*@paramdirections

*@return

*/

publicstaticAnt[]getAntList(int[]positions,int[]directions){

Antant3=newAnt(positions[0],directions[0]);

Antant7=newAnt(positions[1],directions[1]);

Antant11=newAnt(positions[2],directions[2]);

Antant17=newAnt(positions[3],directions[3]);

Antant23=newAnt(positions[4],directions[4]);

returnnewAnt[]{ant3,ant7,ant11,ant17,ant23};

}

/**

*判斷是否所有的Ant都已經走出了木桿,也就是設置退出條件

*

*@paramantArray

*@return

*/

publicstaticbooleanisAllOut(Ant[]antArray){

for(Antant:antArray){

if(ant.isOut()==false){

returnfalse;

}

}

returntrue;

}

}

編程:用C語言實現一個revert函數,它的功能是將輸入的字符串在原串上倒序后返回。

2編程:

用C語言實現函數void*memmove(void*dest,constvoid*src,size_tn)。memmove函數的功能是拷貝src所指的內存內容前n個字節到dest所指的地址上。

3英文拼寫糾錯:

在用戶輸入英文單詞時,經常發生錯誤,我們需要對其進行糾錯。假設已經有一個包含了正確英文單詞的詞典,請你設計一個拼寫糾錯的程序。

(1)請描述你解決這個問題的思路;

(2)請給出主要的處理流程,算法,以及算法的復雜度;

(3)請描述可能的改進(改進的方向如效果,性能等等,這是一個開放問題)。

4尋找熱門查詢:

搜索引擎會通過日志文件把用戶每次檢索使用的所有檢索串都記錄下來,每個查詢串的長度為1-255字節。假設目前有一千萬個記錄,這些查詢串的重復度比較高,雖然總數是1千萬,但如果除去重復后,不超過3百萬個。一個查詢串的重復度越高,說明查詢它的用戶越多,也就是越熱門。請你統計最熱門的10個查詢串,要求使用的內存不能超過1G。

(1)請描述你解決這個問題的思路;

(2)請給出主要的處理流程,算法,以及算法的復雜度。

5集合合并:

給定一個字符串的集合,格式如:

{aaabbbccc},{bbbddd},{eeefff},{ggg},{dddhhh}

要求將其中交集不為空的集合合并,要求合并完成后的集合之間無交集,例如上例應輸出

{aaabbbcccdddhhh},{eeefff},{ggg}

(1)請描述你解決這個問題的思路;

(2)請給出主要的處理流程,算法,以及算法的復雜度

(3)請描述可能的改進(改進的方向如效果,性能等等,這是一個開放問題)。

////////////////////////////////1

1題

char*revert(char*str)

{

intn=strlen(str);

inti=0;

charc;

for(i=0;i

{

c=str;

str=str[n-i];

str[n-i]=c;

}

returnstr;

}

///////////////////////////////////

2題

void*memmove(void*dest,constvoid*src,size_tn)

{

assert((dest!=0)&&(src!=0));

char*temp=(char*)dest;

char*ss=(char*)src;

inti=0;

for(;i

{

*temp++=*ss++;

}

returntemp;

}

/////////////////////////////////////////////////

3題

(1)思路:

字典以字母鍵樹組織,在用戶輸入同時匹配

(2)流程:

每輸入一個字母:沿字典樹向下一層,

a)若可以順利下行,則繼續至結束,給出結果;

b)若該處不能匹配,糾錯處理,給出拼寫建議,繼續至a);

算法:

1.在字典中查找單詞

字典采用27叉樹組織,每個節點對應一個字母,查找就是一個字母一個字母匹配.算法時間就是單詞的長度k.

2.糾錯算法

情況:當輸入的***一個字母不能匹配時就提示出錯,簡化出錯處理,動態提示

可能處理方法:

(a)當前字母前缺少了一個字母:搜索樹上兩層到當前的匹配作為建議;

(b)當前字母拼寫錯誤:當前字母的鍵盤相鄰作為提示;(只是簡單的描述,可以有更多的)

根據分析字典特征和用戶單詞已輸入部分選擇(a),(b)處理

復雜性分析:影響算法的效率主要是字典的實現與糾錯處理

(a)字典的實現已有成熟的算法,改進不大,也不會成為瓶頸;

(b)糾錯策略要簡單有效,如前述情況,是線性復雜度;

(3)改進

策略選擇最是重要,可以采用統計學習的方法改進。

//////////////////////////////////////////////

4題

(1)思路:用哈希做

(2)首先逐次讀入查詢串,算哈希值,保存在內存數組中,同時統計頻度(注意值與日志項對應關系)

選出前十的頻度,取出對應的日志串,簡單不過了。哈希的設計是關鍵。

//////////////////////////////////////////////////

5題

(1)思路:先將集合按照大小排列后,優先考慮小的集合是否與大的集合有交集。有就合并,如果小集合與所有其他集合都沒有交集,則獨立。獨立的集合在下一輪的比較中不用考慮。這樣就可以盡量減少字符串的比較次數。當所有集合都獨立的時候,就終止。

(2)處理流程:

1.將集合按照大小排序,組成集合合并待處理列表

2.選擇最小的集合,找出與之有交集的集合,如果有,合并之;如果無,則與其它集合是獨立集合,從待處理列表中刪除。

3.重復直到待處理列表為空算法:

1。將集合按照大小從小到大排序,組成待處理的集合列表。

2。取出待處理集合列表中最小的集合,對于集合的每個元素,依次在其他集合中搜索是否有此元素存在:

1>若存在,則將此小集合與大集合合并,并根據大小插入對應的位置。轉3。

2>若不存在,則在該集合中取下一個元素。如果無下一個元素,即所有元素都不存在于其他集合。則表明此集合獨立,從待處理集合列表中刪除。并加入結果集合列表。轉3。

3。如果待處理集合列表不為空,轉2。如果待處理集合列表為空,成功退出,則結果集合列表就是最終的輸出。算法復雜度分析:

假設集合的個數為n,***的集合元素為m

排序的時間復雜度可以達到n*log(n)

然后對于元素在其他集合中查找,最壞情況下為(n-1)*m

查找一個集合是否與其他集合有交集的最壞情況是m*m*(n-1)

合并的時間復雜度不會超過查找集合有交集的最壞情況。

所以最終最壞時間復雜度為O(m*m*n*n)需要說明的是:此算法的平均時間復雜度會很低,因為無論是查找還是合并,都是處于最壞情況的概率很小,而且排序后優先用最小集合作為判斷是否獨立的對象,優先與***的集合進行比較,這些都***的回避了最壞情況。

(3)可能的改進:

首先可以實現將每個集合里面的字符串按照字典序進行排列,這樣就可以將查找以及合并的效率增高。另外,可能采取恰當的數據結構也可以將查找以及合并等操作的效率得到提高。

 

【編輯推薦】

  1. 搜狗聯手阿里巴巴VS百度
  2. 百度CEO李彥宏:谷歌退出中國內地犯了大錯
  3. 李彥宏稱百度國際擴張暫避美國
責任編輯:張攀 來源: 網絡
相關推薦

2012-08-15 13:31:02

筆試題

2015-07-21 09:18:09

百度Java研發面試題

2018-03-08 18:40:47

Java百度面試題

2011-07-04 12:18:20

百度翻譯

2012-11-25 15:42:47

互聯網百度搜索

2012-03-23 12:12:37

百度開發者大會

2014-07-25 17:12:39

數據庫WOT2014MongoDB

2013-01-31 09:15:08

偷拍插件美杜莎

2013-08-22 17:08:50

2014-03-07 13:23:23

百度面試iOS

2009-02-27 10:10:13

筆試華為題目

2017-04-28 19:28:39

百度技術學院繁榮技術

2024-12-18 08:33:01

2011-12-20 09:22:37

百度移動云計算

2012-05-28 22:51:53

百度

2015-09-25 16:41:03

APIStore百度技術革新

2024-01-09 07:48:07

推薦排序算法策略數據背景

2015-01-18 15:16:03

百度百度移動分發百度91

2018-09-06 18:37:45

百度云
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 99久久久无码国产精品 | 日日综合 | 伊人青青久久 | 在线一区| www.亚洲精品 | 成人国产精品免费观看视频 | 中文视频在线 | 伊人色综合久久久天天蜜桃 | 看一级毛片视频 | 国产精品美女久久久久久免费 | 国产精品视频偷伦精品视频 | 81精品国产乱码久久久久久 | 日韩免费在线观看视频 | 二区精品 | 午夜免费电影院 | av中文字幕在线 | 久久久久久国产精品久久 | 日日干夜夜干 | 亚洲精品欧美 | 四虎免费视频 | 国产美女黄色 | 国产精品福利视频 | 国产精品高 | 欧美精品久久久 | 成年人免费在线视频 | www操操| 亚洲欧美男人天堂 | 久久久www成人免费无遮挡大片 | 国产成人99av超碰超爽 | 涩涩视频在线播放 | 国产福利在线视频 | 亚洲午夜视频 | 精品国产鲁一鲁一区二区张丽 | 国产精品欧美一区二区三区 | 欧美性大战久久久久久久蜜臀 | 欧美久操网 | 中文在线视频观看 | 日本不卡一二三 | 女人一区 | 亚洲精品一区在线 | 久久一区二区三区四区 |