五、編寫strcpy函式(10分)
已知strcpy函式的原型是
char *strcpy(char *strdest, const char *strsrc);
其中strdest是目的字串,strsrc是源字串。
(1)不呼叫c++/c的字串庫函式,請編寫函式 strcpy
char *strcpy(char *strdest,const char *strsrc)
*srtdest=new char[n];
for(int i=0;i strdest=strsrc[i];
i++;
}return *strdest;
} (2)strcpy能把strsrc的內容複製到strdest,為什麼還要char * 型別的返回值?
因為該函式的還可以把複製的字串首位址指標給其他的指標,而且這種需要也是有用的。
六、編寫類string的建構函式、析構函式和賦值函式(25分)
已知類string的原型為:
class string
;請編寫string的上述4個函式。
//答案一併給出
一、請填寫bool , float, 指標變數與「零值」比較的 if 語句。(10分)
請寫出 bool flag 與「零值」比較的 if 語句。(3分)
標準答案:
if ( flag )
if ( !flag )如下寫法均屬不良風格,不得分。
if (flag == true)
if (flag == 1 )
if (flag == false)
if (flag == 0)
請寫出 float x 與「零值」比較的 if 語句。(4分)
標準答案示例:
const float epsinon = 0.00001;
if ((x >= - epsinon) && (x <= epsinon)
不可將浮點變數用「==」或「!=」與數字比較,應該設法轉化成「>=」或「<=」此類形式。
如下是錯誤的寫法,不得分。
if (x == 0.0)
if (x != 0.0)
請寫出 char *p 與「零值」比較的 if 語句。(3分)
標準答案:
if (p == null)
if (p != null)如下寫法均屬不良風格,不得分。
if (p == 0)
if (p != 0)
if (p)
if (!)
二、以下為windows nt下的32位c++程式,請計算sizeof的值(10分)
char str = 「hello」 ;
char *p = str ;
int n = 10;
請計算sizeof (str ) = 6 (2分)
sizeof ( p ) = 4 (2分)
sizeof ( n ) = 4 (2分)void func ( char str[100])
void *p = malloc( 100 );
請計算sizeof ( p ) = 4 (2分)
三、簡答題(25分)
1、標頭檔案中的 ifndef/define/endif 幹什麼用?(5分)
答:防止該標頭檔案被重複引用。
2、#i nclude 和 #i nclude 「filename.h」 有什麼區別?(5分)
答:對於#i nclude ,編譯器從標準庫路徑開始搜尋 filename.h
對於#i nclude 「filename.h」 ,編譯器從使用者的工作路徑開始搜尋 filename.h
3、const 有什麼用途?(請至少說明兩種)(5分)
答:(1)可以定義 const 常量
(2)const可以修飾函式的引數、返回值,甚至函式的定義體。被const修飾的東西都受到強制保護,可以預防意
外的變動,能提高程式的健壯性。
4、在c++ 程式中呼叫被 c編譯器編譯後的函式,為什麼要加 extern 「c」? (5分)
答:c++語言支援函式過載,c語言不支援函式過載。函式被c++編譯後在庫中的名字與c語言的不同。假設某個函
數的原型為: void foo(int x, int y);
該函式被c編譯器編譯後在庫中的名字為_foo,而c++編譯器則會產生像_foo_int_int之類的名字。
c++提供了c連線交換指定符號extern「c」來解決名字匹配問題。
5、請簡述以下兩個for迴圈的優缺點(5分)
for (i=0; iif (condition)
else
優點:程式簡潔
缺點:多執行了n-1次邏輯判斷,並且打斷了迴圈「流水線」作業,使得編譯器不能對迴圈進行優化處理,降低了
效率。優點:迴圈的效率高
缺點:程式不簡潔
四、有關記憶體的思考題(每小題5分,共20分)
void getmemory(char *p)
void test(void)
請問執行test函式會有什麼樣的結果?
答:程式崩潰。
因為getmemory並不能傳遞動態記憶體,
test函式中的 str一直都是 null。
strcpy(str, "hello world");將使程式崩潰。
char *getmemory(void)
void test(void)
請問執行test函式會有什麼樣的結果?
答:可能是亂碼。
因為getmemory返回的是指向「棧記憶體」的指標,該指標的位址不是 null,但其原現的內容已經被清除,新內容
不可知。
void getmemory2(char **p, int num)
void test(void)
請問執行test函式會有什麼樣的結果?
答:(1)能夠輸出hello
(2)記憶體洩漏
void test(void)
}請問執行test函式會有什麼樣的結果?
答:篡改動態記憶體區的內容,後果難以預料,非常危險。
因為free(str);之後,str成為野指標,
if(str != null)語句不起作用。
27 費波那其數列,1,1,2,3,5……編寫程式求第十項。可以用遞迴,也可以用其他方法,但要說明你選擇的
理由。#i nclude
#i nclude
int pheponatch(int);
int pheponatch2(int);
int main()
//遞迴演算法
int pheponatch(int n)
else
return pheponatch( n -1 ) + pheponatch( n -2 );
}//非遞迴演算法
int pheponatch2(int n)
return y;
}25.完成下列程式
**.*.
*..*..*..
#i nclude
#define n 8
int main()
#i nclude
#i nclude
#define n 8
int main()
{int i;
int j;
int k;
for(i=n; i>=1; i--)
C C 語言程式設計筆試面試題
topfree131 白日?做夢 信譽 100 2006 4 17 10 18 33 得分 0 有乙個陣列a 1000 存放0 1000 要求每隔二個數刪掉乙個數,到末尾時迴圈至開頭繼續進行,求最後乙個被刪掉 的數的原始下標位置。以7個數為例 0 1 2 刪除 3 4 5 刪除 6 7 0 刪除 如...
c c 程式設計面試題
c c 程式設計面試題07 c語言 c 程式設計面試題集錦 第七部分 1.介紹一下stl,詳細說明stl如何實現vector.answer stl 標準模版庫,standard template library.它由容器演算法迭代器組成。stl有以下的一些優點 可以方便容易地實現搜尋資料或對資料排序...
C C 筆試面試題目彙總
4.在什麼時候需要使用 常引用 如果既要利用引用提高程式的效率,又要保護傳遞給函式的資料不在函式中被改變,就應使用常引用。常引用宣告方式 const 型別識別符號 引用名 目標變數名 例1int a const int ra a ra 1 錯誤 a 1 正確 例2string foo void ba...