欧美在线观看www-欧美在线观看高清一二三区-欧美在线观看网站-欧美在线观看网址-国产高清在线精品免费-国产高清在线精品一区二区

當前位置:高考升學網 > 招聘筆試題 > 正文

百度軟件工程師筆試題和面試題答案大全

更新:2023-09-16 00:49:33 高考升學網

  1、實現一個函數,對一個正整數n,算得到1需要的最少操作次數。操作規則為:如果n為偶數,將其除以2;如果n為奇數,可以加1或減1;一直處理下去。

  例子:

  func(7) = 4,可以證明最少需要4次運算

  n = 7

  n-1 6

  n/2 3

  n-1 2

  n/2 1

  要求:實現函數(實現盡可能高效) int func(unsign int n);n為輸入,返回最小的運算次數。給出思路(文字描述),完成代碼,并分析你算法的時間復雜度。

  答:

  [cpp] view plaincopyint func(unsigned int n)

  {

  if(n == 1)

  return 0;

  if(n % 2 == 0)

  return 1 + func(n/2);

  int x = func(n + 1);

  int y = func(n - 1);

  if(x > y)

  return y+1;

  else

  return x+1;

  }

  假設n表示成二進制有x bit,可以看出計算復雜度為O(2^x),也就是O(n)。

  將n轉換到二進制空間來看(比如7為111,6為110):

  - 如果最后一位是0,則對應于偶數,直接進行除2操作。

  - 如果最后一位是1,情況則有些復雜。

  如果最后幾位是???01,則有可能為???001,???1111101。在第一種情況下,顯然應該-1;在第二種情況下-1和+1最終需要的步數相同。所以在???01的情況下,應該選擇-1操作。

  如果最后幾位是???011,則有可能為???0011,???11111011。在第一種情況下,+1和-1最終需要的步數相同;在第二種情況下+1步數更少些。所以在???011的情況下,應該選擇+1操作。

  如果最后有更多的連續1,也應該選擇+1操作。

  如果最后剩下的各位都是1,則有11時應該選擇-1;111時+1和-1相同;1111時應選擇+1;大于四個1時也應該選擇+1;

  [cpp] view plaincopyint func(unsigned int n)

  {

  if(n == 1)

  return 0;

  if(n % 2 == 0)

  return 1 + func(n/2);

  if(n == 3)

  return 2;

  if(n&2)

  return 1 + func(n+1);

  else

  return 1 + func(n-1);

  }

  2、找到滿足條件的數組

  給定函數d(n)=n+n的各位之和,n為正整數,如d(78)=78+7+8=93。這樣這個函數可以看成一個生成器,如93可以看成由78生成。

  定義數A:數A找不到一個數B可以由d(B)=A,即A不能由其他數生成。現在要寫程序,找出1至10000里的所有符合數A定義的數。

  回答:

  申請一個長度為10000的bool數組,每個元素代表對應的值是否可以有其它數生成。開始時將數組中的值都初始化為false。

  由于大于10000的數的生成數必定大于10000,所以我們只需遍歷1到10000中的數,計算生成數,并將bool數組中對應的值設置為true,表示這個數可以有其它數生成。

  最后bool數組中值為false的位置對應的整數就是不能由其它數生成的。

最新圖文

2020年河北新聞網兩學一做

時間:2023-09-18 07:0:24

2020年河北新聞網兩學一做

時間:2023-09-15 11:0:59

兩學一做學習教育知

時間:2023-09-21 06:0:30

2020年開展兩學一做學習教

時間:2023-09-19 21:0:30
主站蜘蛛池模板: 亚洲a网| 久久精品入口麻豆 | 久久精彩免费视频 | 天堂网在线最新版www | 国产一区亚洲二区三区 | 久久国产精品1区2区3区网页 | 五月天婷婷色综合 | 久久国产影视免费精品 | 九九热在线视频观看这里只有精品 | 国产欧美日韩精品高清二区综合区 | 国产另类在线观看 | 中文字幕欧美视频 | 青青草91在线| 精东影业精东影业果冻传媒 | 日本系列 1页 亚洲系列 | 久久综合久久网 | 午夜精品一区二区三区在线观看 | 黄 色 成 年人在线 幻女与人xx00毛片免费 | 欧美乱妇高清视频免欢看关 | 69视频网站| 四虎精品福利视频精品 | 精品一区二区久久 | 中文字幕手机在线播放 | 成人5252色 | 国产在线精品福利一区二区三区 | 国产一区二区精品久久91 | 国产只有精品 | 国产剧情毛片 | 自拍视频在线观看完整版 | 久久久久久久99精品免费 | 清纯唯美综合亚洲第一页 | 亚洲天天综合 | 在线观看免费午夜大片 | 麻豆md传媒新剧国产在线 | 九九视频免费精品视频免费 | 欧美手机在线观看 | 日韩欧美 在线播放 | 爽好舒服宝贝添奶吻戏 | va在线观看 | 国内久久 | 国产在线观看精品香蕉v区 国产在线观看精品 |