閱讀屋>筆試> 華為C++筆試題

華為C++筆試題

華為C++筆試題

  想去面試華為的C++程式設計師?快來看看小編整理的華為C++筆試題吧。

  2017年華為C++筆試題【1】

  1.static有什麼用途?(請至少說明兩種)

  1)在函式體,一個被宣告為靜態的變數在這一函式被呼叫過程中維持其值不變。

  2) 在模組內(但在函式體外),一個被宣告為靜態的變數可以被模組內所用函式訪問,但不能被模組外其它函式訪問。

  它是一個本地的全域性變數。

  3) 在模組內,一個被宣告為靜態的函式只可被這一模組內的其它函式呼叫。

  那就是,這個函式被限制在宣告它的模組的本地範圍內使用。

  2.引用與指標有什麼區別?

  1) 引用必須被初始化,指標不必。

  2) 引用初始化以後不能被改變,指標可以改變所指的物件。

  3) 不存在指向空值的引用,但是存在指向空值的指標。

  3.描述實時系統的基本特性

  在特定時間內完成特定的'任務,實時性與可靠性。

  4.全域性變數和區域性變數在記憶體中是否有區別?如果有,是什麼區別?

  全域性變數儲存在靜態資料庫,區域性變數在堆疊。

  5.什麼是平衡二叉樹?

  左右子樹都是平衡二叉樹 且左右子樹的深度差值的絕對值不大於1。

  6.堆疊溢位一般是由什麼原因導致的?

  沒有回收垃圾資源。

  7.什麼函式不能宣告為虛擬函式?

  constructor函式不能宣告為虛擬函式。

  8.氣泡排序演算法的時間複雜度是什麼?

  時間複雜度是O(n^2)。

  9.寫出float x 與“零值”比較的if語句。

  if(x>0.000001&x<-0.000001)

  10.Internet採用哪種網路協議?該協議的主要層次結構?

  Tcp/Ip協議

  主要層次結構為: 應用層/傳輸層/網路層/資料鏈路層/物理層。

  11.Internet物理地址和IP地址轉換採用什麼協議?

  ARP (Address Resolution Protocol)(地址解析協議)

  12.IP地址的編碼分為哪倆部分?

  IP地址由兩部分組成,網路號和主機號。

  不過是要和“子網掩碼”按位與上之後才能區分哪些是網路位哪些是主機位。

  13.使用者輸入M,N值,從1至N開始順序迴圈數數,每數到M輸出該數值,直至全部輸出。

  寫出C程式。

  迴圈連結串列,用取餘操作做

  14.不能做switch()的引數型別是:

  14.不能做switch()的引數型別是:

  14.不能做switch()的引數型別是:

  switch的引數不能為實型。

  2017年華為C++筆試題【2】

  1. 以下三條輸出語句分別輸出什麼?[C易]

  char str1[] = "abc";

  char str2[] = "abc";

  const char str3[] = "abc";

  const char str4[] = "abc";

  const char* str5 = "abc";

  const char* str6 = "abc";

  cout << boolalpha << ( str1==str2 ) << endl; // 輸出什麼?0

  cout << boolalpha << ( str3==str4 ) << endl; // 輸出什麼?0

  cout << boolalpha << ( str5==str6 ) << endl; // 輸出什麼?1

  2. 非C++內建型別 A 和 B,在哪幾種情況下B能隱式轉化為A?[C++中等]

  答:

  a. class B : public A { } // B公有繼承自A,可以是間接繼承的

  b. class B { operator A( ); } // B實現了隱式轉化為A的轉化

  c. class A { A( const B& ); } // A實現了non-explicit的引數為B(可以有其他帶預設值的引數)建構函式

  d. A& operator= ( const A& ); // 賦值操作,雖不是正宗的隱式型別轉換,但也可以勉強算一個

  3. 以下程式碼中的兩個sizeof用法有問題嗎?[C易]

  void UpperCase( char str[] ) // 將 str 中的小寫字母轉換成大寫字母

  {

  for( size_t i=0; i

  if( 'a'<=str[i] && str[i]<='z' )

  str[i] -= ('a'-'A' );

  }

  char str[] = "aBcDe";

  cout << "str字元長度為: " << sizeof(str)/sizeof(str[0]) << endl;

  UpperCase( str );

  cout << str << endl;

  4. 以下程式碼有什麼問題?[C難]

  void char2Hex( char c ) // 將字元以16進製表示

  {

  char ch = c/0x10 + '0'; if( ch > '9' ) ch += ('A'-'9'-1);

  char cl = c%0x10 + '0'; if( cl > '9' ) cl += ('A'-'9'-1);

  cout << ch << cl << ' ';

  }

  char str[] = "I love 中國";

  for( size_t i=0; i

  char2Hex( str[i] );

  cout << endl;

  5. 以下程式碼有什麼問題?[C++易]

  struct Test

  {

  Test( int ) {}

  Test() {}

  void fun() {}

  };

  void main( void )

  {

  Test a(1);

  a.fun();

  Test b();

  b.fun();

  }

  6. 以下程式碼有什麼問題?[C++易]

  cout << (true?1:"1") << endl;(應該是同種型別,‘1’是隱式的將字元型別轉換成int型,“1”是字串不能自動轉換)

  7. 以下程式碼能夠編譯透過嗎,為什麼?[C++易]

  unsigned int const size1 = 2;

  char str1[ size1 ];

  unsigned int temp = 0;

  cin >> temp;

  unsigned int const size2 = temp;

  char str2[ size2 ];

  8. 以下程式碼中的輸出語句輸出0嗎,為什麼?[C++易]

  struct CLS

  {

  int m_i;

  CLS( int I ) : m_i(i) {}

  CLS()

  {

  CLS(0);

  }

  };

  CLS obj;

  cout << obj.m_i << endl;

  不能,因為m_i沒有初始化,會付一個很大的數

  9. C++中的空類,預設產生哪些類成員函式?[C++易]

  答:

  class Empty

  {

  public:

  Empty(); // 預設建構函式

  Empty( const Empty& ); // 複製建構函式

  ~Empty(); // 解構函式

  Empty& operator=( const Empty& ); // 賦值運算子

  Empty* operator&(); // 取址運算子

  const Empty* operator&() const; // 取址運算子 const

  };

  10. 以下兩條輸出語句分別輸出什麼?[C++難]

  float a = 1.0f;

  cout << (int)a << endl;

  cout << (int&)a << endl;

  cout << boolalpha << ( (int)a == (int&)a ) << endl; // 輸出什麼? Float b = 0.0f;

  cout << (int)b << endl;

  cout << (int&)b << endl;

  cout << boolalpha << ( (int)b == (int&)b ) << endl; // 輸出什麼?

  11. 以下反向遍歷array陣列的方法有什麼錯誤?[STL易]

  vector array;(vector沒有給定具體型別也沒有說明是模板型別) size_type 是無符號整數,當j=0

  時,做減1操作不會得到-1,而是得到最大的無符號整數,因此永遠不會退出迴圈

  array.push_back( 1 );

  array.push_back( 2 );

  array.push_back( 3 );

  for( vector::size_type i=array.size()-1; i>=0; --i) // 反向遍歷array陣列

  {

  cout << array[i] << endl;

  }

  12. 以下程式碼有什麼問題?[STL易]

  typedef vector IntArray;

  IntArray array;

  array.push_back( 1 );

  array.push_back( 2 );

  array.push_back( 2 );

  array.push_back( 3 );

  // 刪除array陣列中所有的2

  for( IntArray::iterator itor=array.begin(); itor!=array.end(); ++itor )

  {

  if( 2 == *itor ) array.erase( itor );

  }

  其實這裡面隱藏著一個很嚴重的錯誤:當veci.erase(iter)之後,iter就變成了一個野指標,對一個野指標進行 iter++ 是肯定會出錯的。

  13. 寫一個函式,完成記憶體之間的複製。

  [考慮問題是否全面]

  答:

  void* mymemcpy( void *dest, const void *src, size_t count )

  {

  char* pdest = static_cast( dest );

  const char* psrc = static_cast( src );

  if( pdest>psrc && pdest

  {

  for( size_t i=count-1; i!=-1; --I )

  pdest[i] = psrc[i];

  }

  else

  {

  for( size_t i=0; i

  pdest[i] = psrc[i];

  }

  return dest;

  }

  int main( void )

  {

  char str[] = "0123456789";

  mymemcpy( str+1, str+0, 9 );

  cout << str << endl;

  system( "Pause" );

  return 0;

  }

【華為C++筆試題】相關文章: