初識(shí)C語言五:函數(shù),宏,遞歸

五:函數(shù)

C程序由函數(shù)組成,所有的C程序都有且僅有一個(gè)main函數(shù),并且main函數(shù)是每段代碼的入口,程序從main函數(shù)出開始運(yùn)作,當(dāng)main函數(shù)結(jié)束時(shí),程序也就結(jié)束了。

函數(shù)是指完成一個(gè)特定工作的獨(dú)立程序模塊?!旌瘮?shù):由C語言系統(tǒng)提供定義 ,函數(shù)類型通常指函數(shù)返回值的類型,如int main(),最后結(jié)尾一定為整數(shù),double main(), 最后結(jié)尾為實(shí)型,也可寫void main ,指的是沒有返回值。如scanf()、printf()等函數(shù)? ??調(diào)用標(biāo)準(zhǔn)庫函數(shù)時(shí),在程序的最前面用#include命令包含相應(yīng)的頭文件。如#include <math.h>

#include <filename.h>???? 用于系統(tǒng)頭文件

#include?? "filename.h"??? 用于用戶頭文件

¨自定義函數(shù):需要用戶自己定義程序中一旦調(diào)用了某個(gè)函數(shù),該函數(shù)就會(huì)完成特定的計(jì)算,然后返回到調(diào)用它的地方。函數(shù)經(jīng)過運(yùn)算,得到一個(gè)明確的運(yùn)算結(jié)果,并需要回送該結(jié)果。






宏定義:
#define 宏名標(biāo)識(shí)符? 宏定義字符串

編譯時(shí),把程序中所有與宏名相同的字符串,用宏定義字符串替代

#define PI 3.14

#define arr_size? 4

說明:

¨宏名一般用大寫字母,以與變量名區(qū)別

¨宏定義不是C語句,后面不得跟分號(hào)

¨宏定義可以嵌套使用

? #define PI 3.14

? #define S 2*PI*PI


宏定義可以寫在程序中任何位置,它的作用范圍從定義書寫處到文件尾。

可以通過“#undef”強(qiáng)制指定宏的結(jié)束范圍


編譯預(yù)處理是C語言編譯程序的組成部分,它用于解釋處理C語言源程序中的各種預(yù)處理指令。

文件包含(#include)和宏定義(#define)都是編譯預(yù)處理指令

¨在形式上都以“#”開頭,不屬于C語言中真正的語句

¨增強(qiáng)了C語言的編程功能,改進(jìn)C語言程序設(shè)計(jì)環(huán)境,提高編程效率


由于#define等編譯預(yù)處理指令不是C語句,不能被編譯程序翻譯,需要在真正編譯之前作一個(gè)預(yù)處理,解釋完成編譯預(yù)處理指令,從而把預(yù)處理指令轉(zhuǎn)換成相應(yīng)的C程序段,最終成為由純粹C語句構(gòu)成的程序,經(jīng)編譯最后得到目標(biāo)代碼。



遞歸:

以漢諾塔問題為例

遞歸方法的兩個(gè)要點(diǎn)

(1)遞歸出口:一個(gè)盤子的解決方法;

(2)遞歸式子:如何把搬動(dòng)64個(gè)盤子的問題簡化成搬動(dòng)63個(gè)盤子的問題。

把漢諾塔的遞歸解法歸納成三個(gè)步驟:

n-1個(gè)盤子從座A搬到座C

第n號(hào)盤子從座A搬到座B

n-1個(gè)盤子從座C搬到座B

算法:hanio(n個(gè)盤,A→B,C為過渡)???

{?if (n == 1)

?????? 直接把盤子A→B

???else{

??????? hanio(n-1個(gè)盤,A→C,B為過渡)

? ??? 把第n號(hào)盤 A→B

? ???? hanio(n-1個(gè)盤,C→B,A為過渡)

? ? }

}


實(shí)現(xiàn):void hanio(int n,char a,char b,char c){

if(n==1){

printf("%c->%c\n",a,b);

}

else {

hanio(n-1,a,c,b);

printf("%c->%c\n",a,b);

hanio(n-1,c,b,a);

}

}

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容