C語言if else語句彙總

對於很多情況,順序結構的代碼是遠遠不夠的,大家都接觸過C語言吧,下面是小編爲大家整理的C語言if else語句,希望對大家有所幫助。

C語言if else語句彙總

C語言if else語句

在C語言中,使用if和else關鍵字對條件進行判斷。請先看下面的代碼:

#includeint main(){ int age; printf("請輸入你的年齡:"); scanf("%d", &age); if(age>=18){ printf("恭喜,你已經成年,可以使用該軟件! "); }else{ printf("抱歉,你還未成年,不宜使用該軟件! "); } return 0;}

可能的運行結果:

請輸入你的年齡:23↙

恭喜,你已經成年,可以使用該軟件!

或者:

請輸入你的年齡:16

抱歉,你還未成年,不宜使用該軟件!

這段代碼中,age>=18是需要判斷的條件,>=表示“大於等於”,等價於數學中的≥。

如果條件成立,也即 age 大於或者等於 18,那麼執行if後面的語句(第8行);如果條件不成立,也即 age 小於 18,那麼執行else後面的語句(第10行)。

if 和 else 是兩個新的關鍵字,if 意爲“如果”,else 意爲“否則”,用來對條件進行判斷,並根據判斷結果執行不同的語句。總結起來,if else 的結構爲:

if(判斷條件){

語句塊1

}else{

語句塊2

}

意思是,如果判斷條件成立,那麼執行語句塊1,否則執行語句塊2 。其執行過程可表示爲下圖:

所謂語句塊(Statement Block),就是由{ }包圍的一個或多個語句的集合。如果語句塊中只有一個語句,也可以省略{ },例如:

if(age>=18) printf("恭喜,你已經成年,可以使用該軟件! ");else printf("抱歉,你還未成年,不宜使用該軟件! ");

由於if else 語句可以根據不同的情況執行不同的代碼,所以也叫分支結構或選擇結構,上面的代碼中,就有兩個分支。

求兩個數中的較大值:

#includeint main(){ int a, b, max; printf("輸入兩個整數:"); scanf("%d %d", &a, &b); if(a>b) max=a; else max=b; printf("%d和%d的較大值是:%d ", a, b, max); return 0;}

運行結果:

輸入兩個整數:34 28↙

34和28的較大值是:34

本例中藉助變量max,用max來保存較大的值,最後將max輸出。

只使用if語句

有的時候,我們需要在滿足某種條件時進行一些操作,而不滿足條件時就不進行任何操作,這個時候我們可以只使用 if 語句。也就是說,if else 不必同時出現。

單獨使用 if 語句的形式爲:

if(判斷條件){

語句塊

}

意思是,如果判斷條件成立就執行語句塊,否則直接跳過。其執行過程可表示爲下圖:

只使用 if 語句來求兩個數中的較大值:

#includeint main(){ int a, b, max; printf("輸入兩個整數:"); scanf("%d %d", &a, &b); max=b; // 假設b最大 if(a>b) max=a; // 如果a>b,那麼更改max的值 printf("%d和%d的較大值是:%d ", a, b, max); return 0;}

運行結果:

輸入兩個整數:34 28

34和28的較大值是:34

本例程序中,輸入兩個數a、b。把b先賦予變量max,再用 if 語句判別max和b的大小,如max小於b,則把b賦予max。因此max中總是大數,最後輸出max的值。

多個if else語句

if else 語句也可以多個同時使用,構成多個分支,形式如下:

if(判斷條件1){

語句塊1

} else if(判斷條件2){

語句塊2

}else if(判斷條件3){

語句塊3

}else if(判斷條件m){

語句塊m

}else{

語句塊n

}

意思是,從上到下依次檢測判斷條件,當某個判斷條件成立時,則執行其對應的語句塊,然後跳到整個 if else 語句之外繼續執行其他代碼。如果所有判斷條件都不成立,則執行語句塊n,然後繼續執行後續代碼。

也就是說,一旦遇到能夠成立的判斷條件,則不再執行其他的語句塊,所以最終只能有一個語句塊被執行。

例如,使用多個 if else 語句判斷輸入的字符的類別:

#includeint main(){ char c; printf("Input a character:"); c=get); if(c<32) this="" is="" a="" else="" c="">='0'&&c<='9') this="" is="" a="" else="" c="">='A'&&c<='z') this="" is="" a="" capital="" else="" c="">='a'&&c<='z') printf("This is a small letter "); else printf("This is an other character "); return 0;}

運行結果:

Input a character:e↙

This is a small letter

本例要求判別鍵盤輸入字符的類別。可以根據輸入字符的ASCII碼來判別類型。由ASCII碼錶可知ASCII值小於32的爲控制字符。在“0”和“9”之間的爲數字,在“A”和“Z”之間爲大寫字母, 在“a”和“z”之間爲小寫字母,其餘則爲其它字符。這是一個多分支選擇的問題,用多個 if else 語句編程,判斷輸入字符ASCII碼所在的範圍,分別給出不同的輸出。例如輸入爲“e”,輸出顯示它爲小寫字符。

在使用 if 語句時還應注意以下兩點:

在 if 語句中,判斷條件必須用括號括起來。

語句塊由{ }包圍,但要注意的是在}之後不需要再加分號;(當然加上也沒錯)。

if語句的嵌套

if 語句也可以嵌套使用,例如:

#includeint main(){ int a,b; printf("Input two numbers:"); scanf("%d %d",&a,&b); if(a!=b){ //!=表示不等於 if(a>b) printf("a>b "); else printf("a

運行結果:

Input two numbers:12 68

a<b< p="">

if 語句嵌套時,要注意 if 和 else 的配對問題。C語言規定,else 總是與它前面最近的 if 配對,例如:

if(a!=b) // ①if(a>b) printf("a>b "); // ②else printf("a

③和②配對,而不是和①配對。

C語言宏定義

宏定義是預處理命令的`一種,它允許用一個標識符來表示一個字符串。先看一個例子:

#include#define N 100int main(){ int sum = 20 + N; printf("%d ", sum); return 0;}

運行結果:

120

該示例中的語句int sum = 20 + N;,N被100代替了。

#define N 100就是宏定義,N爲宏名,100是宏的內容。在編譯預處理時,對程序中所有出現的“宏名”,都用宏定義中的字符串去代換,這稱爲“宏代換”或“宏展開”。

宏定義是由源程序中的宏定義命令#define完成的,宏代換是由預處理程序完成的。

宏定義的一般形式爲:

#define 宏名 字符串

#表示這是一條預處理命令,所有的預處理命令都以#開頭。define是預處理命令。宏名是標識符的一種,命名規則和標識符相同。字符串可以是常數、表達式等。

這裏所說的字符串是一般意義上的字符序列,不要和C語言中的字符串等同,它不需要雙引號。

程序中反覆使用的表達式就可以使用宏定義,例如:

#define M (n*n+3*n)

它的作用是指定標識符M來代替表達式(y*y+3*y)。在編寫源程序時,所有的(y*y+3*y)都可由M代替,而對源程序編譯時,將先由預處理程序進行宏代換,即用(y*y+3*y)表達式去替換所有的宏名M,然後再進行編譯。

將上面的例子補充完整:

#include#define M (n*n+3*n)int main(){ int sum, n; printf("Input a number: "); scanf("%d", &n); sum = 3*M+4*M+5*M; printf("sum=%d ", n); return 0;}

運行結果:

Input a number: 10↙

sum=1560

上面的程序中首先進行宏定義,定義M來替代表達式(n*n+3*n),在sum=3*M+4*M+5*M中作了宏調用。在預處理時經宏展開後該語句變爲:

sum=3*(n*n+3*n)+4*(n*n+3*n)+5*(n*n+3*n);

需要注意的是,在宏定義中表達式(n*n+3*n)兩邊的括號不能少,否則會發生錯誤。如當作以下定義後:

#difine M n*n+3*n

在宏展開時將得到下述語句:

s=3*n*n+3*n+4*n*n+3*n+5*n*n+3*n;

這相當於:

3n2+3n+4n2+3n+5n2+3n

這顯然是不正確的。所以進行宏定義時要注意,應該保證在宏代換之後不發生錯誤。

對宏定義的幾點說明

1、 宏定義是用宏名來表示一個字符串,在宏展開時又以該字符串取代宏名,這只是一種簡單的替換。字符串中可以含任何字符,可以是常數,也可以是表達式,預處理程序對它不作任何檢查,如有錯誤,只能在編譯已被宏展開後的源程序時發現。

2、 宏定義不是說明或語句,在行末不必加分號,如加上分號則連分號也一起替換。

3、 宏定義必須寫在函數之外,其作用域爲宏定義命令起到源程序結束。如要終止其作用域可使用#undef命令。例如:

#define PI 3.14159int main(){ // Code return 0;}#undef PIvoid func(){ // Code}

表示PI只在main函數中有效,在func中無效。

4、宏名在源程序中若用引號括起來,則預處理程序不對其作宏代換,例如:

#include#define OK 100int main(){ printf("OK "); return 0;}

運行結果:

OK

該例中定義宏名OK表示100,但在 printf 語句中 OK 被引號括起來,因此不作宏代換,而作爲字符串處理。

5、宏定義允許嵌套,在宏定義的字符串中可以使用已經定義的宏名,在宏展開時由預處理程序層層代換。例如:

#define PI 3.1415926

#define S PI*y*y /* PI是已定義的宏名*/

對語句:

printf("%f", S);

在宏代換後變爲:

printf("%f", 3.1415926*y*y);

6、 習慣上宏名用大寫字母表示,以便於與變量區別。但也允許用小寫字母。

7、可用宏定義表示數據類型,使書寫方便。例如:

#define UINT unsigned int

在程序中可用UINT作變量說明:

UINT a, b;

應注意用宏定義表示數據類型和用typedef定義數據說明符的區別。宏定義只是簡單的字符串代換,是在預處理完成的,而typedef是在編譯時處理的,它不是作簡單的代換,而是對類型說明符重新命名。被命名的標識符具有類型定義說明的功能。

請看下面的例子:

#define PIN1 int *

typedef (int *) PIN2;

從形式上看這兩者相似, 但在實際使用中卻不相同。

下面用PIN1,PIN2說明變量時就可以看出它們的區別:

PIN1 a,b;

在宏代換後變成:

int *a,b;

表示a是指向整型的指針變量,而b是整型變量。然而:

PIN2 a,b;

表示a、b都是指向整型的指針變量。因爲PIN2是一個類型說明符。由這個例子可見,宏定義雖然也可表示數據類型, 但畢竟是作字符代換。在使用時要分外小心,以避出錯。