對於很多情況,順序結構的程式碼是遠遠不夠的,大家都接觸過C語言吧,下面是小編為大家整理的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是一個型別說明符。由這個例子可見,巨集定義雖然也可表示資料型別, 但畢竟是作字元代換。在使用時要分外小心,以避出錯。