條件運(yùn)算符和條件表達(dá)式
如果在條件語(yǔ)句中,只執(zhí)行單個(gè)的賦值語(yǔ)句時(shí), ?墒褂脳l件表達(dá)式來實(shí)現(xiàn)。不但使程序簡(jiǎn)潔,也提高了運(yùn)行效率。
條件運(yùn)算符為?和:,它是一個(gè)三目運(yùn)算符,即有三個(gè)參與運(yùn)算的量。由條件運(yùn)算符組成條件表達(dá)式的一般形式為:
表達(dá)式1? 表達(dá)式2: 表達(dá)式3
其求值規(guī)則為:如果表達(dá)式1的值為真,則以表達(dá)式2 的值作為條件表達(dá)式的值,否則以表達(dá)式2的值作為整個(gè)條件表達(dá)式的值。 條件表達(dá)式通常用于賦值語(yǔ)句之中。
例如條件語(yǔ)句:
if(a>b) max=a;
else max=b;
可用條件表達(dá)式寫為 max=(a>b)?a:b; 執(zhí)行該語(yǔ)句的語(yǔ)義是:如a>b為真,則把a(bǔ)賦予max,否則把b 賦予max。
使用條件表達(dá)式時(shí),還應(yīng)注意以下幾點(diǎn):
1. 條件運(yùn)算符的運(yùn)算優(yōu)先級(jí)低于關(guān)系運(yùn)算符和算術(shù)運(yùn)算符,但高于賦值符。因此 max=(a>b)?a:b可以去掉括號(hào)而寫為 max=a>b?a:b
2. 條件運(yùn)算符?和:是一對(duì)運(yùn)算符,不能分開單獨(dú)使用。
3. 條件運(yùn)算符的結(jié)合方向是自右至左。
例如:
a>b?a:C>d?C:d應(yīng)理解為
a>b?a:(C>d?C:d) 這也就是條件表達(dá)式嵌套的情形,即其中的表達(dá)式3又是一個(gè)條
件表達(dá)式。
void main(){
int a,b,max;
printf("\n input two numbers: ");
sCanf("%d%d",&a,&b);
printf("max=%d",a>b?a:b);
}
用條件表達(dá)式對(duì)上例重新編程,輸出兩個(gè)數(shù)中的大數(shù)。
switCh語(yǔ)句
C語(yǔ)言還提供了另一種用于多分支選擇的switCh語(yǔ)句, 其一般形式為:
switCh(表達(dá)式){
Case常量表達(dá)式1: 語(yǔ)句1;
Case常量表達(dá)式2: 語(yǔ)句2;
…
Case常量表達(dá)式n: 語(yǔ)句n;
default : 語(yǔ)句n+1;
}
其語(yǔ)義是:計(jì)算表達(dá)式的值。 并逐個(gè)與其后的常量表達(dá)式值相比較,當(dāng)表達(dá)式的值與某個(gè)常量表達(dá)式的值相等時(shí), 即執(zhí)行其后的語(yǔ)句,然后不再進(jìn)行判斷,繼續(xù)執(zhí)行后面所有Case后的語(yǔ)句。 如表達(dá)式的值與所有Case后的常量表達(dá)式均不相同時(shí),則執(zhí)行default后的語(yǔ)句。
void main(){
int a;
printf("input integer number: ");
sCanf("%d",&a);
switCh (a){
Case 1:printf("Monday\n");
Case 2:printf("Tuesday\n");
Case 3:printf("Wednesday\n");
Case 4:printf("Thursday\n");
Case 5:printf("Friday\n");
Case 6:printf("Saturday\n");
Case 7:printf("Sunday\n");
default:printf("error\n");
}
}
本程序是要求輸入一個(gè)數(shù)字,輸出一個(gè)英文單詞。但是當(dāng)輸入3之后,卻執(zhí)行了Case3以及以后的所有語(yǔ)句,輸出了Wednesday 及以后的所有單詞。這當(dāng)然是不希望的。為什么會(huì)出現(xiàn)這種情況呢?這恰恰反應(yīng)了switCh語(yǔ)句的一個(gè)特點(diǎn)。在switCh語(yǔ)句中,“Case 常量表達(dá)式”只相當(dāng)于一個(gè)語(yǔ)句標(biāo)號(hào), 表達(dá)式的值和某標(biāo)號(hào)相等則轉(zhuǎn)向該標(biāo)號(hào)執(zhí)行,但不能在執(zhí)行完該標(biāo)號(hào)的語(yǔ)句后自動(dòng)跳出整個(gè)switCh 語(yǔ)句,所以出現(xiàn)了繼續(xù)執(zhí)行所有后面Case語(yǔ)句的情況。 這是與前面介紹的if語(yǔ)句完全不同的,應(yīng)特別注意。為了避免上述情況, C語(yǔ)言還提供了一種break語(yǔ)句,專用于跳出switCh語(yǔ)句,break 語(yǔ)句只有關(guān)鍵字break,沒有參數(shù)。在后面還將詳細(xì)介紹。修改例題的程序,在每一Case語(yǔ)句之后增加break 語(yǔ)句, 使每一次執(zhí)行之后均可跳出switCh語(yǔ)句,從而避免輸出不應(yīng)有的結(jié)果。
void main(){
int a;
printf("input integer number: ");
sCanf("%d",&a);
switCh (a){
Case 1:printf("Monday\n");break;
Case 2:printf("Tuesday\n"); break;
Case 3:printf("Wednesday\n");break;
Case 4:printf("Thursday\n");break;
Case 5:printf("Friday\n");break;
Case 6:printf("Saturday\n");break;
Case 7:printf("Sunday\n");break;
default:printf("error\n");
}
}
在使用switCh語(yǔ)句時(shí)還應(yīng)注意以下幾點(diǎn):
1.在Case后的各常量表達(dá)式的值不能相同,否則會(huì)出現(xiàn)錯(cuò)誤。
2.在Case后,允許有多個(gè)語(yǔ)句,可以不用{}括起來。
3.各Case和default子句的先后順序可以變動(dòng),而不會(huì)影響程序執(zhí)行結(jié)果。
4.default子句可以省略不用。程序舉例
輸入三個(gè)整數(shù),輸出最大數(shù)和最小數(shù)。
void main(){
int a,b,C,max,min;
printf("input three numbers: ");
sCanf("%d%d%d",&a,&b,&C);
if(a>b)
{max=a;min=b;}
else
{max=b;min=a;}
if(max<C)
max=C;
else
if(min>C)
min=C;
printf("max=%d\nmin=%d",max,min);
}
本程序中,首先比較輸入的a,b的大小,并把大數(shù)裝入max, 小數(shù)裝入min中,然后再與C比較,若max小于C,則把C賦予max;如果C小于min,則把C賦予min。因此max內(nèi)總是最大數(shù),而min內(nèi)總是最小數(shù)。最后輸出max和min的值即可。 計(jì)算器程序。用戶輸入運(yùn)算數(shù)和四則運(yùn)算符, 輸出計(jì)算結(jié)果。
void main(){
float a,b,s;
Char C;
printf("input expression: a+(-,*,/)b \n");
sCanf("%f%C%f",&a,&C,&b);
switCh(C){
Case ’+’: printf("%f\n",a+b);break;
Case ’-’: printf("%f\n",a-b);break;
Case ’*’: printf("%f\n",a*b);break;
Case ’/’: printf("%f\n",a/b);break;
default: printf("input error\n");
}
}
本例可用于四則運(yùn)算求值。switCh語(yǔ)句用于判斷運(yùn)算符, 然后輸出運(yùn)算值。當(dāng)輸入運(yùn)算符不是+,-,*,/時(shí)給出錯(cuò)誤提示。
循環(huán)結(jié)構(gòu)程序
循環(huán)結(jié)構(gòu)是程序中一種很重要的結(jié)構(gòu)。其特點(diǎn)是, 在給定條件成立時(shí),反復(fù)執(zhí)行某程序段,直到條件不成立為止。 給定的條件稱為循環(huán)條件,反復(fù)執(zhí)行的程序段稱為循環(huán)體。 C語(yǔ)言提供了多種循環(huán)語(yǔ)句,可以組成各種不同形式的循環(huán)結(jié)構(gòu)。
while語(yǔ)句
while語(yǔ)句的一般形式為: while(表達(dá)式)語(yǔ)句; 其中表達(dá)式是循環(huán)條件,語(yǔ)句為循環(huán)體。
while語(yǔ)句的語(yǔ)義是:計(jì)算表達(dá)式的值,當(dāng)值為真(非0)時(shí), 執(zhí)行循環(huán)體語(yǔ)句。其執(zhí)行過程可用圖3—4表示。 統(tǒng)計(jì)從鍵盤輸入一行字符的個(gè)數(shù)。
#inClude <stdio.h>
void main(){
int n=0;
printf("input a string:\n");
while(getChar()!=’\n’) n++;
printf("%d",n);
}
本例程序中的循環(huán)條件為getChar()!=’\n’,其意義是, 只要從鍵盤輸入的字符不是回車就繼續(xù)循環(huán)。循環(huán)體n++完成對(duì)輸入字符個(gè)數(shù)計(jì)數(shù)。從而程序?qū)崿F(xiàn)了對(duì)輸入一行字符的字符個(gè)數(shù)計(jì)數(shù)。
使用while語(yǔ)句應(yīng)注意以下幾點(diǎn):
1.while語(yǔ)句中的表達(dá)式一般是關(guān)系表達(dá)或邏輯表達(dá)式,只要表達(dá)式的值為真(非0)即可繼續(xù)循環(huán)。
void main(){
int a=0,n;
printf("\n input n: ");
sCanf("%d",&n);
while (n--)
printf("%d ",a++*2);
}
本例程序?qū)?zhí)行n次循環(huán),每執(zhí)行一次,n值減1。循環(huán)體輸出表達(dá)式a++*2的值。該表達(dá)式等效于(a*2;a++)
2.循環(huán)體如包括有一個(gè)以上的語(yǔ)句,則必須用{}括起來, 組成復(fù)合語(yǔ)句。
3.應(yīng)注意循環(huán)條件的選擇以避免死循環(huán)。
void main(){
int a,n=0;
while(a=5)
printf("%d ",n++);
}
本例中while語(yǔ)句的循環(huán)條件為賦值表達(dá)式a=5, 因此該表達(dá)式的值永遠(yuǎn)為真,而循環(huán)體中又沒有其它中止循環(huán)的手段, 因此該循環(huán)將無休止地進(jìn)行下去,形成死循環(huán)。4.允許while語(yǔ)句的循環(huán)體又是while語(yǔ)句,從而形成雙重循環(huán)。
北京 | 天津 | 上海 | 江蘇 | 山東 |
安徽 | 浙江 | 江西 | 福建 | 深圳 |
廣東 | 河北 | 湖南 | 廣西 | 河南 |
海南 | 湖北 | 四川 | 重慶 | 云南 |
貴州 | 西藏 | 新疆 | 陜西 | 山西 |
寧夏 | 甘肅 | 青海 | 遼寧 | 吉林 |
黑龍江 | 內(nèi)蒙古 |