邏輯運(yùn)算符和表達(dá)式
邏輯運(yùn)算符C語言中提供了三種邏輯運(yùn)算符 && 與運(yùn)算 || 或運(yùn)算 ! 非運(yùn)算 與運(yùn)算符&&和或運(yùn)算符||均為雙目運(yùn)算符。具有左結(jié)合性。 非
運(yùn)算符!為單目運(yùn)算符,具有右結(jié)合性。邏輯運(yùn)算符和其它運(yùn)算符優(yōu)先級(jí)的關(guān)系可表示如下:
按照運(yùn)算符的優(yōu)先順序可以得出:
a>b && C>d等價(jià)于(a>b) && (C>d)
!b==C||d a+b>C && x+yC) && ((x+y) 邏輯運(yùn)算的值
邏輯運(yùn)算的值也為“真”和“假”兩種,用“1”和“0 ”來表示。其求值規(guī)則如下:
1.與運(yùn)算&&參與運(yùn)算的兩個(gè)量都為真時(shí),結(jié)果才為真,否則為假。例如,5>0 && 4>2,由于5>0為真,4>2也為真,相與的結(jié)果也為真。
2.或運(yùn)算||參與運(yùn)算的兩個(gè)量只要有一個(gè)為真,結(jié)果就為真。 兩個(gè)量都為假時(shí),結(jié)果為假。例如:5>0||5>8,由于5>0為真,相或的結(jié)果也就為真
3.非運(yùn)算!參與運(yùn)算量為真時(shí),結(jié)果為假;參與運(yùn)算量為假時(shí),結(jié)果為真。
例如:!(5>0)的結(jié)果為假。
雖然C編譯在給出邏輯運(yùn)算值時(shí),以“1”代表“真”,“0 ”代表“假”。 但反過來在判斷一個(gè)量是為“真”還是為“假”時(shí),以“0”代表“假”,以非“0”的數(shù)值作為“真”。例如:由于5和3均為非“0”因此5&&3的值為“真”,即為1。
又如:5||0的值為“真”,即為1。
邏輯表達(dá)式邏輯表達(dá)式的一般形式為: 表達(dá)式 邏輯運(yùn)算符 表達(dá)式 其中的表達(dá)式可以又是邏輯表達(dá)式,從而組成了嵌套的情形。例如:(a&&b)&&C根據(jù)邏輯運(yùn)算符的左結(jié)合性,上式也可寫為: a&&b&&C 邏輯表達(dá)式的值是式中各種邏輯運(yùn)算的最后值,以“1”和“0”分別代表“真”和“假”。
void main(){
Char C=’k’;
int i=1,j=2,k=3;
float x=3e+5,y=0.85;
printf("%d,%d\n",!x*!y,!!!x);
printf("%d,%d\n",x||i&&j-3,i printf("%d,%d\n",i==5&&C&&(j=8),x+y||i+j+k);
}
本例中!x和!y分別為0,!x*!y也為0,故其輸出值為0。由于x為非0,故!!!x的邏輯值為0。對(duì)x|| i && j-3式,先計(jì)算j-3的值為非0,再求i && j-3的邏輯值為1,故x||i&&j-3的邏輯值為 1。對(duì)i if語句
用if語句可以構(gòu)成分支結(jié)構(gòu)。它根據(jù)給定的條件進(jìn)行判斷, 以決定執(zhí)行某個(gè)分支程序段。C語言的if語句有三種基本形式。 來源:www.examda.com
1.第一種形式為基本形式 if(表達(dá)式) 語句; 其語義是:如果表達(dá)式的值為真,則執(zhí)行其后的語句, 否則不執(zhí)行該語句。其過程可表示為下圖
void main(){
int a,b,max;
printf("\n input two numbers: ");
sCanf("%d%d",&a,&b);
max=a;
if (max printf("max=%d",max);
}
輸入兩個(gè)整數(shù),輸出其中的大數(shù)。
sCanf("%d%d",&a,&b);
max=a;
if (max printf("max=%d",max);
本例程序中,輸入兩個(gè)數(shù)a,b。把a(bǔ)先賦予變量max,再用if語句判別max和b的大小,如max小于b,則把b賦予max。因此max中總是大數(shù),最后輸出max的值。
邏輯運(yùn)算符C語言中提供了三種邏輯運(yùn)算符 && 與運(yùn)算 || 或運(yùn)算 ! 非運(yùn)算 與運(yùn)算符&&和或運(yùn)算符||均為雙目運(yùn)算符。具有左結(jié)合性。 非
運(yùn)算符!為單目運(yùn)算符,具有右結(jié)合性。邏輯運(yùn)算符和其它運(yùn)算符優(yōu)先級(jí)的關(guān)系可表示如下:
按照運(yùn)算符的優(yōu)先順序可以得出:
a>b && C>d等價(jià)于(a>b) && (C>d)
!b==C||d a+b>C && x+yC) && ((x+y) 邏輯運(yùn)算的值
邏輯運(yùn)算的值也為“真”和“假”兩種,用“1”和“0 ”來表示。其求值規(guī)則如下:
1.與運(yùn)算&&參與運(yùn)算的兩個(gè)量都為真時(shí),結(jié)果才為真,否則為假。例如,5>0 && 4>2,由于5>0為真,4>2也為真,相與的結(jié)果也為真。
2.或運(yùn)算||參與運(yùn)算的兩個(gè)量只要有一個(gè)為真,結(jié)果就為真。 兩個(gè)量都為假時(shí),結(jié)果為假。例如:5>0||5>8,由于5>0為真,相或的結(jié)果也就為真
3.非運(yùn)算!參與運(yùn)算量為真時(shí),結(jié)果為假;參與運(yùn)算量為假時(shí),結(jié)果為真。
例如:!(5>0)的結(jié)果為假。
雖然C編譯在給出邏輯運(yùn)算值時(shí),以“1”代表“真”,“0 ”代表“假”。 但反過來在判斷一個(gè)量是為“真”還是為“假”時(shí),以“0”代表“假”,以非“0”的數(shù)值作為“真”。例如:由于5和3均為非“0”因此5&&3的值為“真”,即為1。
又如:5||0的值為“真”,即為1。
邏輯表達(dá)式邏輯表達(dá)式的一般形式為: 表達(dá)式 邏輯運(yùn)算符 表達(dá)式 其中的表達(dá)式可以又是邏輯表達(dá)式,從而組成了嵌套的情形。例如:(a&&b)&&C根據(jù)邏輯運(yùn)算符的左結(jié)合性,上式也可寫為: a&&b&&C 邏輯表達(dá)式的值是式中各種邏輯運(yùn)算的最后值,以“1”和“0”分別代表“真”和“假”。
void main(){
Char C=’k’;
int i=1,j=2,k=3;
float x=3e+5,y=0.85;
printf("%d,%d\n",!x*!y,!!!x);
printf("%d,%d\n",x||i&&j-3,i printf("%d,%d\n",i==5&&C&&(j=8),x+y||i+j+k);
}
本例中!x和!y分別為0,!x*!y也為0,故其輸出值為0。由于x為非0,故!!!x的邏輯值為0。對(duì)x|| i && j-3式,先計(jì)算j-3的值為非0,再求i && j-3的邏輯值為1,故x||i&&j-3的邏輯值為 1。對(duì)i if語句
用if語句可以構(gòu)成分支結(jié)構(gòu)。它根據(jù)給定的條件進(jìn)行判斷, 以決定執(zhí)行某個(gè)分支程序段。C語言的if語句有三種基本形式。 來源:www.examda.com
1.第一種形式為基本形式 if(表達(dá)式) 語句; 其語義是:如果表達(dá)式的值為真,則執(zhí)行其后的語句, 否則不執(zhí)行該語句。其過程可表示為下圖
void main(){
int a,b,max;
printf("\n input two numbers: ");
sCanf("%d%d",&a,&b);
max=a;
if (max printf("max=%d",max);
}
輸入兩個(gè)整數(shù),輸出其中的大數(shù)。
sCanf("%d%d",&a,&b);
max=a;
if (max printf("max=%d",max);
本例程序中,輸入兩個(gè)數(shù)a,b。把a(bǔ)先賦予變量max,再用if語句判別max和b的大小,如max小于b,則把b賦予max。因此max中總是大數(shù),最后輸出max的值。