溧陽(yáng)手機(jī)網(wǎng)站哪里做/學(xué)it什么培訓(xùn)機(jī)構(gòu)好
C語(yǔ)言 | 問(wèn)題20230225
文章目錄
- C語(yǔ)言 | 問(wèn)題`20230225`
- 1.`問(wèn)題1`
- 無(wú)限循環(huán)
- 2.問(wèn)題2
- C 中的運(yùn)算符優(yōu)先級(jí)
- 實(shí)例1:
1.問(wèn)題1
Which slice of the following code is NOT endless loop?
以下代碼的哪一部分不是無(wú)限循環(huán)?
A
for (;(c=getchar())!='\n'; ) printf("*c",c);
B
for(;;x+=1 );
C
while(x=1){ x++;}
D
for(i=10;;i--) sum += i;
A選項(xiàng),運(yùn)行時(shí),不輸入換行,就會(huì)一直在循環(huán);
B是死循環(huán);
C是死循環(huán);
D是死循環(huán);
getchar
()用來(lái)從標(biāo)準(zhǔn)輸入設(shè)備中讀取一個(gè)字符。然后將該字符從unsigned char
轉(zhuǎn)換成int
后返回。
getchar
()會(huì)返回讀取到的字符,若返回EOF
則表示有錯(cuò)誤發(fā)生。C for 循環(huán):https://www.runoob.com/cprogramming/c-for-loop.html
C 語(yǔ)言中 for 循環(huán)的語(yǔ)法:
for ( init; condition; increment ) { statement(s); }
下面是 for 循環(huán)的控制流:
- init 會(huì)首先被執(zhí)行,且只會(huì)執(zhí)行一次。這一步允許您聲明并初始化任何循環(huán)控制變量。您也可以不在這里寫(xiě)任何語(yǔ)句,只要有一個(gè)分號(hào)出現(xiàn)即可。
- 接下來(lái),會(huì)判斷 condition。如果為真,則執(zhí)行循環(huán)主體。如果為假,則不執(zhí)行循環(huán)主體,且控制流會(huì)跳轉(zhuǎn)到緊接著 for 循環(huán)的下一條語(yǔ)句。
- 在執(zhí)行完 for 循環(huán)主體后,控制流會(huì)跳回上面的 increment 語(yǔ)句。該語(yǔ)句允許您更新循環(huán)控制變量。該語(yǔ)句可以留空,只要在條件后有一個(gè)分號(hào)出現(xiàn)即可。
- 條件再次被判斷。如果為真,則執(zhí)行循環(huán),這個(gè)過(guò)程會(huì)不斷重復(fù)(循環(huán)主體,然后增加步值,再然后重新判斷條件)。在條件變?yōu)榧贂r(shí),for 循環(huán)終止。
無(wú)限循環(huán)
如果條件永遠(yuǎn)不為假,則循環(huán)將變成無(wú)限循環(huán)。for 循環(huán)在傳統(tǒng)意義上可用于實(shí)現(xiàn)無(wú)限循環(huán)。由于構(gòu)成循環(huán)的三個(gè)表達(dá)式中任何一個(gè)都不是必需的,您可以將某些條件表達(dá)式留空來(lái)構(gòu)成一個(gè)無(wú)限循環(huán)。
#include <stdio.h>int main () {for( ; ; ){printf("該循環(huán)會(huì)永遠(yuǎn)執(zhí)行下去!\n");}return 0; }
當(dāng)條件表達(dá)式不存在時(shí),它被假設(shè)為真。您也可以設(shè)置一個(gè)初始值和增量表達(dá)式,但是一般情況下,C 程序員偏向于使用
for(;;)
結(jié)構(gòu)來(lái)表示一個(gè)無(wú)限循環(huán)。**注意:**您可以按
Ctrl + C
鍵終止一個(gè)無(wú)限循環(huán)。
2.問(wèn)題2
#include <stdio.h>int main(void)
{int C;int a,b;a =5;b =7;C = a +++ b;printf("a: %d, b: %d, C: %d\n", a,b,C);
}
運(yùn)行結(jié)果:
PS D:\05_study\mark-down-doc\02-cStudy\source> make 01-test gcc -o 01-test 01-test.c -g -Wall PS D:\05_study\mark-down-doc\02-cStudy\source> .\01-test.exe a: 6, b: 7, C: 12
C 運(yùn)算符:https://www.runoob.com/cprogramming/c-operators.html
C 中的運(yùn)算符優(yōu)先級(jí)
運(yùn)算符的優(yōu)先級(jí)確定表達(dá)式中項(xiàng)的組合。這會(huì)影響到一個(gè)表達(dá)式如何計(jì)算。某些運(yùn)算符比其他運(yùn)算符有更高的優(yōu)先級(jí),例如,乘除運(yùn)算符具有比加減運(yùn)算符更高的優(yōu)先級(jí)。
例如 x = 7 + 3 * 2,在這里,x 被賦值為 13,而不是 20,因?yàn)檫\(yùn)算符 * 具有比 + 更高的優(yōu)先級(jí),所以首先計(jì)算乘法 3*2,然后再加上 7。
下表將按運(yùn)算符優(yōu)先級(jí)從高到低列出各個(gè)運(yùn)算符,具有較高優(yōu)先級(jí)的運(yùn)算符出現(xiàn)在表格的上面,具有較低優(yōu)先級(jí)的運(yùn)算符出現(xiàn)在表格的下面。在表達(dá)式中,較高優(yōu)先級(jí)的運(yùn)算符會(huì)優(yōu)先被計(jì)算。
類(lèi)別 | 運(yùn)算符 | 結(jié)合性 |
---|---|---|
后綴 | () [] -> . ++ - - | 從左到右 |
一元 | + - ! ~ ++ - - (type)* & sizeof | 從右到左 |
乘除 | * / % | 從左到右 |
加減 | + - | 從左到右 |
移位 | << >> | 從左到右 |
關(guān)系 | < <= > >= | 從左到右 |
相等 | == != | 從左到右 |
位與 AND | & | 從左到右 |
位異或 XOR | ^ | 從左到右 |
位或 OR | | | 從左到右 |
邏輯與 AND | && | 從左到右 |
邏輯或 OR | || | 從左到右 |
條件 | ?: | 從右到左 |
賦值 | = += -= *= /= %=>>= <<= &= ^= |= | 從右到左 |
逗號(hào) | , | 從左到右 |
實(shí)例1:
#include <stdio.h>int main()
{int a = 21;int b = 10;int c ;c = a + b;printf("Line 1 - c 的值是 %d\n", c );c = a - b;printf("Line 2 - c 的值是 %d\n", c );c = a * b;printf("Line 3 - c 的值是 %d\n", c );c = a / b;printf("Line 4 - c 的值是 %d\n", c );c = a % b;printf("Line 5 - c 的值是 %d\n", c );c = a++; // 賦值后再加 1 ,c 為 21,a 為 22printf("Line 6 - c 的值是 %d\n", c );c = a--; // 賦值后再減 1 ,c 為 22 ,a 為 21printf("Line 7 - c 的值是 %d\n", c );
}
運(yùn)行:
PS D:\05_study\mark-down-doc\02-cStudy\source> make 01-test
gcc -o 01-test 01-test.c -g -Wall
PS D:\05_study\mark-down-doc\02-cStudy\source> .\01-test.exe
Line 1 - c 的值是 31
Line 2 - c 的值是 11
Line 3 - c 的值是 210
Line 4 - c 的值是 2
Line 5 - c 的值是 1
Line 6 - c 的值是 21
Line 7 - c 的值是 22