網站首頁 個人範例 行業範例 行政範例 職場範例 校園範例 書信範例 生活範例 節日文化範例
當前位置:文學範文吧 > 職場範例 > 筆試

華為C++筆試題

欄目: 筆試 / 發佈於: / 人氣:4.69K

想去面試華為的C++程序員?快來看看小編整理的華為C++筆試題吧。

華為C++筆試題

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

ic有什麼用途?(請至少説明兩種)

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)

rnet採用哪種網絡協議?該協議的主要層次結構?

Tcp/Ip協議

主要層次結構為: 應用層/傳輸層/網絡層/數據鏈路層/物理層。

rnet物理地址和IP地址轉換採用什麼協議?

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

地址的編碼分為哪倆部分?

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);

();

Test b();

();

}

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,而是得到最大的無符號整數,因此永遠不會退出循環

_back( 1 );

_back( 2 );

_back( 3 );

for( vector::size_type i=()-1; i>=0; --i) // 反向遍歷array數組

{

cout << array[i] << endl;

}

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

typedef vector IntArray;

IntArray array;

_back( 1 );

_back( 2 );

_back( 2 );

_back( 3 );

// 刪除array數組中所有的2

for( IntArray::iterator itor=n(); itor!=(); ++itor )

{

if( 2 == *itor ) e( itor );

}

其實這裏面隱藏着一個很嚴重的錯誤:當e(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;

}

Tags:華為 筆試