華為校園招聘筆試算法題匯總_第1頁
已閱讀1頁,還剩12頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)

文檔簡介

1、<p><b>  華為筆試算法題匯總</b></p><p>  1.通過鍵盤輸入一串小寫字母(a~z)組成的字符串。請編寫一個字符串過濾程序,若字符串中出現(xiàn)多個相同的字符,將非首次出現(xiàn)的字符過濾掉。</p><p>  比如字符串“abacacde”過濾結(jié)果為“abcde”。</p><p>  要求實(shí)現(xiàn)函數(shù):void strin

2、gFilter(const char *pInputStr, long lInputLen, char *pOutputStr);</p><p>  【輸入】 pInputStr:  輸入字符串</p><p>  lInputLen:  輸入字符串長度         <

3、/p><p>  【輸出】 pOutputStr: 輸出字符串,空間已經(jīng)開辟好,與輸入字符串等長; </p><p>  【注意】只需要完成該函數(shù)功能算法,中間不需要有任何IO的輸入輸出</p><p><b>  示例 </b></p><p>  輸入:“deefd”   

4、;     輸出:“def”</p><p>  輸入:“afafafaf”     輸出:“af”</p><p>  輸入:“pppppppp”     輸出:“p”</p><p>  main函數(shù)已經(jīng)隱藏,這里保留給用戶的測試入口,在這里測

5、試你的實(shí)現(xiàn)函數(shù),可以調(diào)用printf打印輸出</p><p>  當(dāng)前你可以使用其他方法測試,只要保證最終程序能正確執(zhí)行即可,該函數(shù)實(shí)現(xiàn)可以任意修改,但是不要改變函數(shù)原型。</p><p>  一定要保證編譯運(yùn)行不受影響</p><p>  [cpp] view plaincopy</p><p>  ////////////////////

6、//////////////////////////////////////////////////////</p><p>  #include <iostream>    </p><p>  #include <cassert>    </p>&

7、lt;p>  using namespace std;    </p><p>  bool g_flag[26];    </p><p>  void stringFilter(const char *pInputStr, long

8、 lInputLen, char *pOutputStr)    </p><p><b>  {    </b></p><p>  assert(pInputStr != NULL);    &l

9、t;/p><p>  int i = 0;    </p><p>  if (pInputStr == NULL || lInputLen <= 1)    </p><p><

10、b>  {    </b></p><p>  return;    </p><p><b>  }    </b></p><p>  const char *p =

11、0;pInputStr;    </p><p>  while(*p != '\0')    </p><p><b>  {    </b></p><p>  if (g_f

12、lag[(*p - 'a')])    </p><p><b>  {    </b></p><p><b>  p++;    </b></p><p>  }e

13、lse{    </p><p>  pOutputStr[i++] = *p;    </p><p>  g_flag[*p - 'a'] = 1;    </p><p&

14、gt;<b>  p++;    </b></p><p><b>  }    </b></p><p><b>  }    </b></p><p>  pOutputStr[

15、i] = '\0';    </p><p><b>  }    </b></p><p>  int main()    </p><p><b>  { 

16、   </b></p><p>  memset(g_flag,0,sizeof(g_flag));    </p><p>  char input[] = "abacacde";    </p><

17、;p>  char *output = new char[strlen(input) + 1];    </p><p>  stringFilter(input,strlen(input),output);    </p><p>  cout

18、<<output<<endl;    </p><p>  delete output;    </p><p>  return 0;    </p><p><b>  } 

19、60;  </b></p><p><b>  2.</b></p><p>  通過鍵盤輸入一串小寫字母(a~z)組成的字符串。請編寫一個字符串壓縮程序,將字符串中連續(xù)出席的重復(fù)字母進(jìn)行壓縮,并輸出壓縮后的字符串。</p><p><b>  壓縮規(guī)則:</b></p>&l

20、t;p>  1、僅壓縮連續(xù)重復(fù)出現(xiàn)的字符。比如字符串"abcbc"由于無連續(xù)重復(fù)字符,壓縮后的字符串還是"abcbc"。</p><p>  2、壓縮字段的格式為"字符重復(fù)的次數(shù)+字符"。例如:字符串"xxxyyyyyyz"壓縮后就成為"3x6yz"。</p><p><b>

21、;  要求實(shí)現(xiàn)函數(shù): </b></p><p>  void stringZip(const char *pInputStr, long lInputLen, char *pOutputStr);</p><p>  【輸入】 pInputStr:  輸入字符串</p><p>  lInputLen:  輸入字符串長度&l

22、t;/p><p>  【輸出】 pOutputStr: 輸出字符串,空間已經(jīng)開辟好,與輸入字符串等長;</p><p>  【注意】只需要完成該函數(shù)功能算法,中間不需要有任何IO的輸入輸出</p><p><b>  示例 </b></p><p>  輸入:“cccddecc”   輸出:“3

23、c2de2c”</p><p>  輸入:“adef”     輸出:“adef”</p><p>  輸入:“pppppppp” 輸出:“8p”</p><p>  [cpp] view plaincopy</p><p>  /////////////////////////////////////

24、/////////////////////////////////////   </p><p>  #include <iostream>    </p><p>  #include <cassert>    </p>

25、<p>  using namespace std;    </p><p>  void stringZip(const char *pInputStr, long lInputLen, char *pOutputStr)    &l

26、t;/p><p><b>  {    </b></p><p>  const char *p = pInputStr;    </p><p>  int num = 1;  

27、  </p><p>  int i = 0;    </p><p><b>  p++;    </b></p><p>  while(*p != NULL)  

28、0; </p><p><b>  {    </b></p><p>  while(*p == *(p-1)&& *p != NULL)    </p><p><b>  {

29、    </b></p><p>  num++;    </p><p><b>  p++;    </b></p><p><b>  }    </b

30、></p><p>  if (num > 1)    </p><p><b>  {    </b></p><p>  int size = 0;   

31、60;</p><p>  int temp = num;    </p><p>  while(num)             //計(jì)算位數(shù)    

32、;</p><p><b>  {    </b></p><p>  size++;    </p><p>  num /= 10;    </p><p><b> 

33、 }    </b></p><p>  num = 1;    </p><p>  for (int j = size; j > 0; j--)    

34、;</p><p><b>  {    </b></p><p>  pOutputStr[i+j-1] = '0'+ temp%10;    </p><p>  temp /= 10; 

35、;   </p><p><b>  }    </b></p><p>  i +=size;    </p><p>  pOutputStr[i++] = *(p-1);  

36、60; </p><p><b>  p++;    </b></p><p>  }else{    </p><p>  pOutputStr[i++] = *(p-1);    </p

37、><p><b>  p++;    </b></p><p><b>  }    </b></p><p><b>  }    </b></p><p> 

38、 pOutputStr[i] = '\0';    </p><p><b>  }    </b></p><p>  int main()    </p><p><b&

39、gt;  {    </b></p><p>  char input[] = "cccddecc";    </p><p>  char *output = new char[strlen(input)&#

40、160;+ 1];    </p><p>  stringZip(input,strlen(input),output);    </p><p>  cout<<output<<endl;    </p><p&g

41、t;  return 0;    </p><p><b>  }    </b></p><p>  3.通過鍵盤輸入100以內(nèi)正整數(shù)的加、減運(yùn)算式,請編寫一個程序輸出運(yùn)算結(jié)果字符串。</p><p>  輸入字符串的格式為:“操作數(shù)1 運(yùn)算符 操作數(shù)2

42、”,“操作數(shù)”與“運(yùn)算符”之間以一個空格隔開。</p><p><b>  補(bǔ)充說明:</b></p><p>  1、操作數(shù)為正整數(shù),不需要考慮計(jì)算結(jié)果溢出的情況。</p><p>  2、若輸入算式格式錯誤,輸出結(jié)果為“0”。</p><p><b>  要求實(shí)現(xiàn)函數(shù): </b><

43、;/p><p>  void arithmetic(const char *pInputStr, long lInputLen, char *pOutputStr);</p><p>  【輸入】 pInputStr:  輸入字符串</p><p>  lInputLen:  輸入字符串長度     

44、    </p><p>  【輸出】 pOutputStr: 輸出字符串,空間已經(jīng)開辟好,與輸入字符串等長; </p><p>  【注意】只需要完成該函數(shù)功能算法,中間不需要有任何IO的輸入輸出</p><p><b>  示例 </b></p><p> 

45、 輸入:“4 + 7”  輸出:“11”</p><p>  輸入:“4 - 7”  輸出:“-3”</p><p>  輸入:“9 ++ 7”  輸出:“0” 注:格式錯誤</p><p>  [cpp] view plaincopy</p><p>  ////////////////////////////

46、//////////////////////////////////////////////  </p><p>  #include <iostream>    </p><p>  using namespace std;    </p&g

47、t;<p>  void arithmetic(const char *pInputStr, long lInputLen, char *pOutputStr)    </p><p><b>  {    </b></p&

48、gt;<p>  const char *input = pInputStr;    </p><p>  char *output = pOutputStr;    </p><p>  int sum =

49、 0;    </p><p>  int operator1 = 0;    </p><p>  int operator2 = 0;    </p><p>  char&

50、#160;*temp = new char[5];    </p><p>  char *ope = temp;    </p><p>  while(*input != ' ') //獲得操

51、作數(shù)1    </p><p><b>  {    </b></p><p>  sum = sum*10 + (*input++ - '0');    </p>

52、;<p><b>  }    </b></p><p>  input++;    </p><p>  operator1 = sum;    </p><p>  sum =&

53、#160;0;    </p><p>  while(*input != ' ')    </p><p><b>  {    </b></p><p>  *temp++&#

54、160;= *input++;    </p><p><b>  }    </b></p><p>  input++;    </p><p>  *temp = '\0';

55、    </p><p>  if (strlen(ope) > 1 )    </p><p><b>  {    </b></p><p>  *output++ 

56、= '0';    </p><p>  *output = '\0';    </p><p>  return;    </p><p><b>  } 

57、0;  </b></p><p>  while(*input != '\0') //獲得操作數(shù)2    </p><p><b>  {    </b></p><p>  sum

58、60;= sum*10 + (*input++ - '0');    </p><p><b>  }    </b></p><p>  operator2 = sum;  

59、0; </p><p>  sum = 0;    </p><p>  switch (*ope)    </p><p><b>  {    </b></p><

60、;p>  case '+':itoa(operator1+operator2,pOutputStr,10);    </p><p>  break;    </p><p>  case '-':itoa(operator1-operator2,pOu

61、tputStr,10);    </p><p>  break;    </p><p>  default:    </p><p>  *output++ = '0';   &

62、#160;</p><p>  *output = '\0';    </p><p>  return;    </p><p><b>  }    </b></p>&l

63、t;p><b>  }    </b></p><p>  int main()    </p><p><b>  {    </b></p><p>  char input

64、[] = "4 - 7";    </p><p>  char output[] = "    ";    </p><p>  arithmetic(inpu

65、t,strlen(input),output);    </p><p>  cout<<output<<endl;    </p><p>  return 0;    </p><p><b>  }

66、    </b></p><p>  4.輸入1--50個數(shù)字,求出最小數(shù)和最大數(shù)的和</p><p>  [cpp] view plaincopy</p><p>  //華為2014年機(jī)試題1:輸入1--50個數(shù)字,求出最小數(shù)和最大數(shù)的和    </p>&

67、lt;p>  //輸入以逗號隔開    </p><p>  #include<stdio.h>    </p><p>  #define N 50    </p><p>  void sort(

68、int a[],int n);    </p><p>  int main(void)    </p><p><b>  {        </b></p>&l

69、t;p>  char str[100];    </p><p>  int a[N]={0};    </p><p>  gets(str);      //要點(diǎn)1:動態(tài)的輸入1--50個整數(shù),不能確定個數(shù),只能用字符串輸

70、入,然后分離出來    </p><p>  int i=0;    </p><p>  int j=0;    </p><p>  int sign=1;    </

71、p><p>  while(str[i]!='\0')    </p><p><b>  {    </b></p><p>  if(str[i]!=',')  //輸入時要在半角輸入  

72、60; </p><p><b>  {    </b></p><p>  if(str[i] == '-')    //要點(diǎn):2:有負(fù)整數(shù)的輸入    </p><p><

73、;b>  {    </b></p><p>  // i++;   //易錯點(diǎn)1    </p><p>  sign=-1;    </p><p><b>  } 

74、   </b></p><p>  else if(str[i]!='\0') //不用else的話,負(fù)號也會減去‘0’    </p><p><b>  {    </b></p><p&

75、gt;  a[j]=a[j]*10 + str[i]-'0'; //要點(diǎn)3:輸入的可以是多位數(shù)    </p><p><b>  }    </b></p><p><b>  }    &l

76、t;/b></p><p><b>  i++;    </b></p><p>  if(str[i]==',' || str[i]=='\0')  //這個判斷是在i自加以后    </p>&

77、lt;p><b>  {    </b></p><p>  a[j]=a[j]*sign;  //易錯點(diǎn)2    </p><p>  sign=1;   ////易錯點(diǎn)3    </p

78、><p>  j++;    //j就是a數(shù)組的個數(shù) 范圍0到j(luò)-1    </p><p><b>  }    </b></p><p><b>  }    <

79、;/b></p><p>  sort(a,j);    </p><p>  printf("Max number + Min number = %d",a[0]+a[j-1]);    </p><p&

80、gt;  return 0;    </p><p><b>  }    </b></p><p>  void sort(int a[],int n)  //選擇排序    </p

81、><p><b>  {    </b></p><p>  int i,j;    </p><p>  int k;    </p><p>  int temp;

82、0;   </p><p>  for(i=0;i<n-1;i++)    </p><p><b>  {    </b></p><p><b>  k=i;    </

83、b></p><p>  for(j=i+1;j<n;j++)    </p><p><b>  {    </b></p><p>  if(a[k]>a[j])    </p><p

84、><b>  k=j;    </b></p><p><b>  }    </b></p><p>  if(i!=k)    </p><p><b>  {  

85、  </b></p><p>  temp = a[k];    </p><p>  a[k] = a[i];    </p><p>  a[i] = temp;  

86、60; </p><p><b>  }    </b></p><p><b>  }    </b></p><p>  for(i=0;i<n;i++)    </p>

87、<p>  printf("%-5d",a[i]);    </p><p>  puts("");    </p><p><b>  }    </b></p><p>

88、<b>  初始化順序表</b></p><p><b>  計(jì)算線性表的長度</b></p><p><b>  插入結(jié)點(diǎn)</b></p><p><b>  追加結(jié)點(diǎn)</b></p><p><b>  刪除結(jié)點(diǎn)</b></

89、p><p><b>  查找結(jié)點(diǎn)</b></p><p><b>  按照序號查找結(jié)點(diǎn)</b></p><p><b>  按照關(guān)鍵字查找結(jié)點(diǎn)</b></p><p><b>  顯示所有的結(jié)點(diǎn)</b></p><p><b>

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論