C語言題庫帶詳細(xì)講解答案解析.doc
《C語言題庫帶詳細(xì)講解答案解析.doc》由會(huì)員分享,可在線閱讀,更多相關(guān)《C語言題庫帶詳細(xì)講解答案解析.doc(59頁珍藏版)》請?jiān)谘b配圖網(wǎng)上搜索。
1、 WORD格式整理版一單項(xiàng)選擇題1( A )是構(gòu)成C語言程序的基本單位。A、函數(shù) B、過程 C、子程序 D、子例程2C語言程序從 C 開始執(zhí)行。 A) 程序中第一條可執(zhí)行語句 B) 程序中第一個(gè)函數(shù)C) 程序中的main函數(shù) D) 包含文件中的第一個(gè)函數(shù)3、以下說法中正確的是( C )。 A、C語言程序總是從第一個(gè)定義的函數(shù)開始執(zhí)行 B、在C語言程序中,要調(diào)用的函數(shù)必須在main( )函數(shù)中定義 C、C語言程序總是從main( )函數(shù)開始執(zhí)行 D、C語言程序中的main( )函數(shù)必須放在程序的開始部分4.下列關(guān)于C語言的說法錯(cuò)誤的是( B ) 。A) C程序的工作過程是編輯、編譯、連接、運(yùn)行
2、B) C語言不區(qū)分大小寫。C) C程序的三種基本結(jié)構(gòu)是順序、選擇、循環(huán) D) C程序從main函數(shù)開始執(zhí)行5.下列正確的標(biāo)識(shí)符是(C)。A.-a1 B.ai C.a2_i D.int t58題為相同類型題考點(diǎn):標(biāo)識(shí)符的命名規(guī)則(1) 只能由字母、數(shù)字、下劃線構(gòu)成(2) 數(shù)字不能作為標(biāo)識(shí)符的開頭(3) 關(guān)鍵字不能作為標(biāo)識(shí)符選項(xiàng)A中的“-” ,選項(xiàng)B中“”與“”不滿足(1);選項(xiàng)D中的int為關(guān)鍵字,不滿足(3)6下列C語言用戶標(biāo)識(shí)符中合法的是( B )。 A)3ax B)x C)case D)-e2 E)union選項(xiàng)A中的標(biāo)識(shí)符以數(shù)字開頭不滿足(2);選項(xiàng)C,E均為為關(guān)鍵字,不滿足(3);選項(xiàng)
3、D中的“-”不滿足(1);7下列四組選項(xiàng)中,正確的C語言標(biāo)識(shí)符是( C )。A) %x B) a+b C) a123 D) 123選項(xiàng)A中的“%” ,選項(xiàng)B中“+”不滿足(1);選項(xiàng)D中的標(biāo)識(shí)符以數(shù)字開頭不滿足(2)8、下列四組字符串中都可以用作C語言程序中的標(biāo)識(shí)符的是( A )。 A、print _3d db8 aBc B、Iam one_half start$it 3pai C、str_1 Cpp pow while D、Pxq My-book line# His.age 選項(xiàng)B中的“”,”$” ,選項(xiàng)D中“”,”#”,”.”,”-”不滿足(1);選項(xiàng)C中的while為關(guān)鍵字,不滿足(3)
4、9.C語言中的簡單數(shù)據(jù)類型包括(D )。 A、整型、實(shí)型、邏輯型 B、整型、實(shí)型、邏輯型、字符型 C、整型、字符型、邏輯型 D、整型、實(shí)型、字符型10.在C語言程序中,表達(dá)式5%2的結(jié)果是 C 。 A)2.5 B)2 C)1 D)3詳見教材P5253.%為求余運(yùn)算符,該運(yùn)算符只能對(duì)整型數(shù)據(jù)進(jìn)行運(yùn)算。且符號(hào)與被模數(shù)相同。5%2=1; 5%(-2)=1;(-5)%2=-1;(-5)%(-2)=-1;/為求商運(yùn)算符,該運(yùn)算符能夠?qū)φ?、字符、浮點(diǎn)等類型的數(shù)據(jù)進(jìn)行運(yùn)算,5/2=211如果int a=3,b=4;則條件表達(dá)式ab? a:b的值是_A_。A) 3 B) 4 C) 0 D) 1詳見教材P97
5、.表達(dá)式1?表達(dá)式2:表達(dá)式3先計(jì)算表達(dá)式1,若表達(dá)式1成立, 則選擇計(jì)算表達(dá)式2,并表達(dá)式2的值作為整個(gè)大表達(dá)式的值;若表達(dá)式1不成立,則選擇計(jì)算表達(dá)式3,并將表達(dá)式3的值作為整個(gè)大表達(dá)式的值此題中的ab相當(dāng)于表達(dá)式1,a相當(dāng)于表達(dá)式2,b相當(dāng)于表達(dá)式3.a為3,b為4。ab表達(dá)式1成立,因此計(jì)算表達(dá)式2,并將表達(dá)式2的值即a中的值,并作為整個(gè)表達(dá)式的值,因此整個(gè)表達(dá)式的值為312若int x=2,y=3,z=4 則表達(dá)式xage D) (*p).age33.設(shè)有如下定義:struck sk int a;float b;data;int *p;若要使P指向data中的a域,正確的賦值語句是
6、C A) p=&a;B) p=data.a;C) p=&data.a;D)*p=data.a;34.設(shè)有以下說明語句: typedef struct stu int a; float b; stutype; 則下面敘述中錯(cuò)誤的是( D )。 A、struct是結(jié)構(gòu)類型的關(guān)鍵字 B、struct stu是用戶定義的結(jié)構(gòu)類型 C、a和b都是結(jié)構(gòu)成員名D、stutype是用戶定義的結(jié)構(gòu)體變量名35 語句int *p;說明了 C 。A)p是指向一維數(shù)組的指針 B)p是指向函數(shù)的指針,該函數(shù)返回一int型數(shù)據(jù)C)p是指向int型數(shù)據(jù)的指針 / 指針的定義教材P223D)p是函數(shù)名,該函數(shù)返回一指向int
7、型數(shù)據(jù)的指針36下列不正確的定義是(A )。A. int *p=&i,i; B.int *p,i;Cint i,*p=&i; D.int i,*p;選項(xiàng)A先定義一個(gè)整型指針變量p,然后將變量i的地址賦給p。然而此時(shí)還未定義變量i因此編譯器無法獲得變量i的地址。(A與C對(duì)比,選項(xiàng)C先定義變量i,則在內(nèi)存中為i分配空間,因此i在內(nèi)存空間的地址就可以確定了;然后再定義p,此時(shí)可以為p賦i的地址,C正確)37. 若有說明:int n=2,*p=&n,*q=p,則以下非法的賦值語句是: (D )A)p=q B)*p=*q C)n=*q D)p=np,q同為整型指針變量,二者里面僅能存放整型變量的地址。選
8、項(xiàng)A,q中為地址,因此可將此地址賦給p選項(xiàng)B,*p表示p所指向?qū)ο髇的內(nèi)容,即一個(gè)整數(shù);*q表示q所指向?qū)ο蟮膬?nèi)容,由于在定義q時(shí)為其初始化,將p中n的地址給q,因此p中存放n的地址,*q表示q所指向?qū)ο髇的內(nèi)容.因此*p=*q 相當(dāng)于 n=n;選項(xiàng)C,n=*q 等價(jià)于n=n;選項(xiàng)D,p中只能存放地址,不能將n中的整數(shù)值賦給p38有語句:int a10,;則 B 是對(duì)指針變量p的正確定義和初始化。A)int p=*a; B)int *p=a; C)int p=&a; D)int *p=&a;選項(xiàng)A,a是數(shù)組名,不是指針變量名,因此不可用*標(biāo)注數(shù)組名a選項(xiàng)C,a是數(shù)組名,數(shù)組名就是地址,無需再用
9、地址符號(hào)。而且在定義指針變量p時(shí),應(yīng)在變量名前加*,標(biāo)明p是指針變量選項(xiàng)D,a是數(shù)組名,數(shù)組名就是地址,無需再用地址符號(hào)。39.若有說明語句“int a5,*p=a;”,則對(duì)數(shù)組元素的正確引用是( C )。A.ap B.pa C.*(p+2) D.p+2首先定義一個(gè)整型數(shù)組a,a的長度為5,然后定義一個(gè)指針變量p,并同時(shí)對(duì)p進(jìn)行初始化,將數(shù)組a的地址賦給p。因此此時(shí)p中存放的數(shù)組a的首地址,即數(shù)組中第一個(gè)元素a0的地址。對(duì)于數(shù)組元素下標(biāo)的引用(詳見p144), 一般形式 數(shù)組名下標(biāo) 其中下標(biāo)為邏輯地址下標(biāo),從0開始計(jì)數(shù),方括號(hào)中的下標(biāo)可以是變量,可以是表達(dá)式,但結(jié)果一定要是整數(shù)。選項(xiàng)A,p中存
10、放的是地址,不是整數(shù),不能做數(shù)組元素的下標(biāo)選項(xiàng)B,a是數(shù)組名,數(shù)組名就是地址,不是整數(shù),不能做數(shù)組元素的下標(biāo)選項(xiàng)C,(重點(diǎn)!詳見p231234) p+2表示指向同一數(shù)組中的下兩個(gè)元素的地址,當(dāng)前p指向a0,則p+2表示a2的地址,因此*(p+2)表示a2的內(nèi)容40. 有如下程序int a10=1,2,3,4,5,6,7,8,9,10,*P=a;則數(shù)值為9的表達(dá)式是 B A) *P+9 B) *(P+8) C) *P+=9 D) P+8(重點(diǎn)!詳見p231234)首先定義一個(gè)整型數(shù)組a,a的長度為5,然后定義一個(gè)指針變量P,并同時(shí)對(duì)P進(jìn)行初始化,將數(shù)組a的地址賦給P。因此此時(shí)P中存放的數(shù)組a的首
11、地址,即數(shù)組中第一個(gè)元素a0的地址。數(shù)組中9對(duì)應(yīng)的是a8, 選項(xiàng)B,P+8表示數(shù)組中后8個(gè)元素的地址,即a8的地址。*(P+8)則表示該地址內(nèi)所存放的內(nèi)容,即a8的值。選項(xiàng)A,*P表示P所指向?qū)ο蟮膬?nèi)容,此時(shí)P指向a0, *P即a0的值1. *P+9=1+9=10選項(xiàng)C,*P表示P所指向?qū)ο蟮膬?nèi)容,此時(shí)P指向a0, *P即a0的值。因此*P+=9 即*P =*P+9, 等價(jià)于a0=a0+9.選項(xiàng)D,P+8表示數(shù)組中后8個(gè)元素的地址,即a8的地址,而非a8中的值。41. 在C語言中,以 D 作為字符串結(jié)束標(biāo)志A)n B) C) 0 D)0 42.下列數(shù)據(jù)中屬于“字符串常量”的是(A )。A.“a
12、” B.ABC C.abc0 D.a若干個(gè)字符構(gòu)成字符串在C語言中,用單引號(hào)標(biāo)識(shí)字符;用雙引號(hào)標(biāo)識(shí)字符串選項(xiàng)B,C,分別用和標(biāo)識(shí)字符串選項(xiàng)D,標(biāo)識(shí)字符。43.已知char x=hello, y=h,e,a,b,e;, 則關(guān)于兩個(gè)數(shù)組長度的正確描述是 B .A)相同 B)x大于y C)x小于y D)以上答案都不對(duì)C語言中,字符串后面需要一個(gè)結(jié)束標(biāo)志位0,通常系統(tǒng)會(huì)自動(dòng)添加。對(duì)一維數(shù)組初始化時(shí)可采用字符串的形式(例如本題數(shù)組x),也可采用字符集合的形式(例如本題數(shù)組y)。在以字符串形式初始化時(shí),數(shù)組x不盡要存儲(chǔ)字符串中的字符,還要存儲(chǔ)字符串后的結(jié)束標(biāo)志位,因此數(shù)組x的長度為6;在以字符集合形式初始
13、化時(shí),數(shù)組y,僅存儲(chǔ)集合中的元素,因此數(shù)組y長度為5一、 讀程序基本輸入輸出及流程控制1.#include main() int a=1,b=3,c=5;if (c=a+b) printf(yesn);else printf(non);運(yùn)行結(jié)果為:no詳見教材p89 選擇結(jié)構(gòu)詳見教材p91關(guān)系符號(hào)詳見附錄D p378符號(hào)的優(yōu)先級(jí)=表示判斷符號(hào)兩邊的值是否相等;=表示將符號(hào)右邊的值賦給左邊的變量本題考點(diǎn)是選擇結(jié)構(gòu)3種基本形式的第二種選擇結(jié)構(gòu)三種一般形式中的“語句”皆為復(fù)合語句,復(fù)合語句要用 括起來,只有當(dāng)復(fù)合語句中只包括一條語句時(shí)可以省略 ,此題即如此,因此兩個(gè)printf操作沒有加 若c=a+
14、b成立,則執(zhí)行printf(yesn);否則(即c=a+b不成立),執(zhí)行printf(non);+的優(yōu)先級(jí)高于=,因此先算a+b,值為4, 表達(dá)式5=4不成立,因此執(zhí)行printf(non);即輸出字符串no2. #include main() int a=12, b= -34, c=56, min=0;min=a; if(minb) min=b; if(minc) min=c;printf(min=%d, min);運(yùn)行結(jié)果為: min=-34詳見教材p89 選擇結(jié)構(gòu)本題考點(diǎn)是選擇結(jié)構(gòu)3種基本形式的第一種一共包含了兩個(gè)選擇結(jié)構(gòu)(兩個(gè)if語句)定義變量,并賦值 此時(shí)a=12, b= -34,
15、c=56, min=0將a中值拷貝,賦給min,覆蓋了min中的0,此時(shí)min中的值被更新為12。若minb成立,則執(zhí)行min=b;若minc成立,則執(zhí)行min=c;輸出min中的值12大于-34,第一個(gè)if語句的表達(dá)式成立,因此執(zhí)行min=b; 執(zhí)行后min中的值被更新為-34.-34小于56,第二個(gè)if語句的表達(dá)式不成立,因此不執(zhí)行min=c;最后輸出min中的值,為-34.3.#include main() int x=2,y= -1,z=5; if(xy)if(y0) z=0;else z=z+1; printf(“%dn”,z); 運(yùn)行結(jié)果為:5遇到選擇結(jié)構(gòu),首先要明確條件表達(dá)式成立
16、時(shí)執(zhí)行哪些操作。本題中,第一個(gè)if語句,其后的復(fù)合語句沒有大括號(hào) ,說明復(fù)合語句中只包含一條語句,進(jìn)而省略了 。內(nèi)層的if.else.是選擇結(jié)構(gòu)的第二種基本形式,在結(jié)構(gòu)上視為一條語句。因此內(nèi)層的if.else.作為第一個(gè)if語句的復(fù)合語句。若表達(dá)式xy成立,則繼續(xù)判斷 若y=0),執(zhí)行z=z+1;輸出z2-1,表達(dá)式xy不成立,因此不執(zhí)行內(nèi)層的ifelse.進(jìn)而z中的值沒有被改變。輸出z中的值為54. #include main() float a,b,c,t;a=3;b=7;c=1;if(ab) t=a;a=b;b=t;if(ac) t=a;a=c;c=t;if(bc) t=b;b=c;c=
17、t;printf(%5.2f,%5.2f,%5.2f,a,b,c); %為求余運(yùn)算 運(yùn)行結(jié)果為:1.00, 3.00, 7.00詳見教材p72數(shù)據(jù)的輸出形式本題包含了3個(gè)if語句,每個(gè)if語句后的 都不可省略,因?yàn)槊總€(gè) 中都包含了多條語句若表達(dá)式ab成立,則執(zhí)行t=a;a=b;b=t;若表達(dá)式ac成立,則執(zhí)行t=a;a=c;c=t;若表達(dá)式bc成立,則執(zhí)行t=b;b=c;c=t;輸出a,b,c中的值,要求輸出的每個(gè)數(shù)據(jù)寬度為5個(gè)空格,小數(shù)部分保留2位,數(shù)據(jù)右對(duì)齊3小于7,因此表達(dá)式ab不成立,因此不執(zhí)行t=a;a=b;b=t;3大于1,因此表達(dá)式ac成立,則執(zhí)行t=a;a=b;b=t;。第一句
18、,將a中的3拷貝,粘貼到t中;第二句,將c中的1拷貝,粘貼到a中,覆蓋掉先前的3;第三句。將t中的3拷貝到c中,覆蓋掉c中先前的1. 執(zhí)行完復(fù)合語句后實(shí)現(xiàn)了a,c元素的值的互換,a為1,c為3,t為3,。7大于c中的3,因此bc成立,執(zhí)行則執(zhí)行t=b;b=c;c=t;,過程同上,執(zhí)行后b為3,c為7,t為7此時(shí)輸出a,b,c中的值為1.00, 2.00, 7.005#include main ( ) float c=3.0 , d=4.0;if ( cd ) c=5.0;else if ( c=d ) c=6.0;else c=7.0; printf ( “%.1fn”,c ) ;運(yùn)行結(jié)果為:
19、7.0此題為if.else.語句的嵌套,第二if.else.作為第一個(gè)if.else.語句else部分的復(fù)合語句。若表達(dá)式cd成立,則執(zhí)行c=5.0;否則(表達(dá)式cd不成立)若表達(dá)式c=d成立,則執(zhí)行c=6.0;否則,執(zhí)行c=7.0;輸出c中的值3.0小于4.0,因此表達(dá)式cd不成立,執(zhí)行第二個(gè)ifelse。3.0不等于4.0,因此表達(dá)式c=d不成立,執(zhí)行c=7.0,將7.0賦給c, 覆蓋掉c中的3.0,此時(shí)c中的值為7.0輸出此時(shí)的c中的值6.#include main()int m;scanf(%d, &m);if (m = 0) if (m%2 = 0)printf(%d is a po
20、sitive evenn, m); elseprintf(%d is a positive oddn, m);else if (m % 2 = 0) printf(%d is a negative evenn, m);else printf(%d is a negative oddn, m);若鍵入9,則運(yùn)行結(jié)果為: -9 is a negative odd7. #include main() int num=0;while(num=2) num+;printf(%dn,num);運(yùn)行結(jié)果為:123詳見教材p115循環(huán)結(jié)構(gòu)當(dāng)循環(huán)條件num=2成立的時(shí)候,執(zhí)行循環(huán)體 num+;printf(%d
21、n,num);中的語句。循環(huán)初值num為0;循環(huán)條件num=2成立第1次循環(huán):執(zhí)行num+;即將num中的值加1,執(zhí)行后num為1;執(zhí)行printf(%dn,num);在屏幕上輸出num中的值,即輸出1,之后換行此時(shí)num中的值為1,循環(huán)條件num=2成立第2此循環(huán):執(zhí)行num+;即將num中的值加1,執(zhí)行后num為2;執(zhí)行printf(%dn,num);在屏幕上輸出num中的值,即輸出2,之后換行此時(shí)num中的值為2,循環(huán)條件num=2成立第3此循環(huán):執(zhí)行num+;即將num中的值加1,執(zhí)行后num為3;執(zhí)行printf(%dn,num);在屏幕上輸出num中的值,即輸出3,之后換行此時(shí)nu
22、m中的值為3,循環(huán)條件num=2不成立,結(jié)束循環(huán)。8#include main( ) int sum=10,n=1;while(n3) sum=sum-n; n+; printf(“%d,%d”,n,sum); 運(yùn)行結(jié)果為:3,7當(dāng)循環(huán)條件n3成立的時(shí)候,執(zhí)行循環(huán)體sum=sum-n; n+; 中的語句。循環(huán)初值sum為10,n為1;循環(huán)條件n3成立第1次循環(huán):執(zhí)行sum=sum-n=10-1=9;執(zhí)行n+,即將n中的值加1,執(zhí)行后n為2;此時(shí)n中的值為2,sum中的值為9,循環(huán)條件n3成立,繼續(xù)執(zhí)行循環(huán)第2次循環(huán):執(zhí)行sum=sum-n=9-2=7;執(zhí)行n+,即將n中的值加1,執(zhí)行后n為3;
23、輸出此時(shí)n,sum中的值,即為3,7。需要注意,在printf(“%d,%d”,n,sum); 中要求輸出的數(shù)據(jù)彼此間用逗號(hào)間隔,因此結(jié)果的兩個(gè)數(shù)據(jù)間一定要有逗號(hào)9.#include main() int num,c; scanf(%d,&num); do c=num%10; printf(%d ,c); while(num/=10)0); num=0printf(n); 從鍵盤輸入23,則運(yùn)行結(jié)果為:3 2詳見教材p117循環(huán)結(jié)構(gòu);p60復(fù)合的賦值運(yùn)算符do while(表達(dá)式);先無條件執(zhí)行循環(huán)體,再判斷循環(huán)條件。注意while(表達(dá)式)后有分號(hào)定義整型變量num,c;為num賦一個(gè)整型值
24、;執(zhí)行c=num%10; printf(%d,c); 直到循環(huán)條件(num/=10)0不成立;輸出換行已知為num賦值23第1次執(zhí)行循環(huán)體執(zhí)行c=num%10=23%10=3;執(zhí)行printf(%d,c);輸出3判斷循環(huán)條件 num/=10等價(jià)于num=num/10; 因此num=23/10=2, 2大于0,因此循環(huán)條件(num/=10)0成立,繼續(xù)執(zhí)行循環(huán)體。執(zhí)行完第1次循環(huán)時(shí),num為2,c為3第2次執(zhí)行循環(huán)體執(zhí)行c=2%10=2;執(zhí)行printf(%d,c);再輸出2判斷循環(huán)條件num=2/10=0,0等于0,因此循環(huán)條件(num/=10)0不成立。結(jié)束循環(huán)10#include main
25、() int s=0,a=5,n;scanf(%d,&n);do s+=1; a=a-2; while(a!=n);printf(%d,%dn,s,a); 若輸入的值1,運(yùn)行結(jié)果為: 2,1 詳見教材p117循環(huán)結(jié)構(gòu);p60復(fù)合的賦值運(yùn)算符執(zhí)行 s+=1; a=a-2; 直到循環(huán)條件a!=n不成立;已知為n賦值1,s為0,a為5第1次執(zhí)行循環(huán)體執(zhí)行s+=1;等價(jià)于s=s+1=0+1執(zhí)行a=a-2; a=5-2=3判斷循環(huán)條件,3不等于1,因此循環(huán)條件a!=n成立,繼續(xù)執(zhí)行循環(huán)體。執(zhí)行完第1次循環(huán)時(shí),s為1,a為3第2次執(zhí)行循環(huán)體執(zhí)行s+=1;等價(jià)于s=s+1=1+1=2執(zhí)行a=a-2; a=3
26、-2=1判斷循環(huán)條件,1等于1,因此循環(huán)條件a!=n不成立,結(jié)束循環(huán)。執(zhí)行完第2次循環(huán)時(shí),s為2,a為1輸出此時(shí)s,a中的值,結(jié)果為2,111#include stdio.h main() char c; c=getchar(); while(c!=?) putchar(c); c=getchar(); 如果從鍵盤輸入abcde?fgh(回車)運(yùn)行結(jié)果為:abcde12#include main() char c; while(c=getchar()!=$) if(A=c&c=Z) putchar(c); else if(a=c&c=z) putchar(c-32); 當(dāng)輸入為ab*AB%cd
27、#CD$時(shí),運(yùn)行結(jié)果為:ABABCDCD13. #include main() int x, y =0;for(x=1;x=10) break; y=y+x; printf(“%d %d”,y,x);運(yùn)行結(jié)果為:10 5詳見教材p120 for語句詳見教材p126128 break,continue語句for(表達(dá)式1;表達(dá)式2;表達(dá)式3)(1) 先求解表達(dá)式1 (2) 求解表達(dá)式2,若其值為真,執(zhí)行循環(huán)體,然后執(zhí)行 (3). 若為假,則結(jié)束循環(huán),轉(zhuǎn)到(5)(3) 求解表達(dá)式3 (4) 轉(zhuǎn)回上面 (2)繼續(xù)執(zhí)行(5) 循環(huán)結(jié)束,執(zhí)行for語句下面的一個(gè)語句 break,跳出循環(huán)體;contin
28、ue,結(jié)束本次循環(huán)(第i次循環(huán)),繼續(xù)執(zhí)行下一次循環(huán)(第i+1次循環(huán))此題 表達(dá)式1為x=1,表達(dá)式2(循環(huán)條件)為x=10,表達(dá)式3為x+初值x為1,y為0,循環(huán)條件(即表達(dá)式2)x=10成立,進(jìn)入循環(huán)體第1次循環(huán)執(zhí)行if語句。0小于10,if語句的條件表達(dá)式不成立,不執(zhí)行break;執(zhí)行y=y+x; y=0+1=1轉(zhuǎn)向表達(dá)式3,執(zhí)行x+, x=x+1=1+1=2。循環(huán)條件x=10成立,進(jìn)入第2次循環(huán)第2次循環(huán)執(zhí)行if語句。1小于10,if語句的條件表達(dá)式不成立,不執(zhí)行break;執(zhí)行y=y+x; y=1+2=3轉(zhuǎn)向表達(dá)式3,執(zhí)行x+, x=x+1=2+1=3。循環(huán)條件x=10成立,進(jìn)入第3
29、次循環(huán)第3次循環(huán)執(zhí)行if語句。3小于10,if語句的條件表達(dá)式不成立,不執(zhí)行break;執(zhí)行y=y+x; y=3+3=6轉(zhuǎn)向表達(dá)式3,執(zhí)行x+, x=x+1=3+1=4。循環(huán)條件x=10成立,進(jìn)入第4次循環(huán)第4次循環(huán)執(zhí)行if語句。6小于10,if語句的條件表達(dá)式不成立,不執(zhí)行break;執(zhí)行y=y+x; y=6+4=10轉(zhuǎn)向表達(dá)式3,執(zhí)行x+, x=x+1=4+1=5。循環(huán)條件x=10成立,進(jìn)入第5次循環(huán)第5次循環(huán)執(zhí)行if語句。10等于10,if語句的條件表達(dá)式成立,執(zhí)行break,跳出循環(huán)。從break跳出至for語句的下一條語句。執(zhí)行printf(“%d %d”,y,x);輸出當(dāng)前的y與x
30、.結(jié)果為10 514.#include main( ) char ch; ch=getchar( ); switch(ch) case A : printf(“%c”,A); case B : printf(“%c”,B); break; default: printf(“%sn”,”other”); 當(dāng)從鍵盤輸入字母A時(shí),運(yùn)行結(jié)果為:AB詳見教材p103,switch語句switch(表達(dá)式) case 常量1 :語句1 case 常量2 :語句2 case 常量n :語句n default : 語句n+1 其中表達(dá)式,常量1,常量n都為整型或字符型case相當(dāng)于給出執(zhí)行程序的入口和起始位置
31、,若找到匹配的常量,則從此處開始往下執(zhí)行程序,不再匹配常量,直至遇到break或switch結(jié)束本題過程:首先從鍵盤接收一個(gè)字符A并將其放在變量ch中。執(zhí)行switch語句。Switch后面的條件表達(dá)式為ch,因此表達(dá)式的值即為字符A. 用字符A依次與下面的 case中的常量匹配。與第1個(gè)case后的常量匹配,則從其后的語句開始往下執(zhí)行程序(在執(zhí)行過程中不再進(jìn)行匹配。)因此先執(zhí)行printf(“%c”,A),屏幕上輸出A;再往下繼續(xù)執(zhí)行printf(“%c”,B),屏幕上輸出B;再繼續(xù)執(zhí)行break, 此時(shí)跳出switch語句。15. #include main( ) int a=1,b=0;
32、 scanf(“%d”,&a);switch(a) case 1: b=1;break;case 2: b=2;break;default : b=10;printf(%d , b);若鍵盤輸入5,運(yùn)行結(jié)果為:10本題過程:首先用scanf函數(shù)為變量a賦值為5。執(zhí)行switch語句。switch后面的條件表達(dá)式為a,因此表達(dá)式的值即為5. 用5依次與下面 case中的常量匹配。沒有找到匹配的常量,因此兩個(gè)case后的語句都不執(zhí)行。執(zhí)行default后面的語句b=10;將10賦給變量b。輸出變量b,結(jié)果為1016. #include main()_ char grade=C; switch(gr
33、ade) case A: printf(“90-100n”); case B: printf(“80-90n”);case C: printf(“70-80n”);case D: printf(“60-70n”); break;case E: printf(“60n”); default : printf(“error!n”); 運(yùn)行結(jié)果為:70-8060-70本題過程:首先從鍵盤接收一個(gè)字符C并將其放在變量grade中。執(zhí)行switch語句。switch后面的條件表達(dá)式為grade,因此表達(dá)式的值即為字符C. 用字符C依次與下面的 case中的常量匹配。與第3個(gè)case后的常量匹配,則從其后
34、的語句開始往下執(zhí)行程序(在執(zhí)行過程中不再進(jìn)行匹配。)因此先執(zhí)行printf(“70-80n”);,屏幕上輸出70-80,并換行;再往下繼續(xù)執(zhí)行printf(“60-70n”),屏幕上輸出60-70,并換行;再繼續(xù)執(zhí)行break, 此時(shí)跳出switch語句。17.#include main() int y=9; for(;y0;y- -)if(y%3=0) printf(%d”,- -y); 運(yùn)行結(jié)果為:852詳見教材p53,自增自減符號(hào)此題 表達(dá)式1被省略,表達(dá)式2(循環(huán)條件)為y0,表達(dá)式3為y-初值y為9,循環(huán)條件(即表達(dá)式2)y0成立,進(jìn)入循環(huán)體第1次循環(huán)執(zhí)行if語句。9%3=0,if語
35、句的條件表達(dá)式成立,執(zhí)行printf(%d”,- -y),即y先自減1變?yōu)?,然后在輸出,因此屏幕上輸出8轉(zhuǎn)向表達(dá)式3,執(zhí)行y-, y=y-1=8-1=7。循環(huán)條件y0成立,進(jìn)入第2次循環(huán)第2次循環(huán)執(zhí)行if語句。7%3不為0,if語句的條件表達(dá)式不成立,不執(zhí)行printf(%d”,- -y)轉(zhuǎn)向表達(dá)式3,執(zhí)行y-, y=y-1=7-1=6。循環(huán)條件y0成立,進(jìn)入第3次循環(huán)第3次循環(huán)執(zhí)行if語句。6%3=0,if語句的條件表達(dá)式成立,執(zhí)行printf(%d”,- -y),即y先自減1變?yōu)?,然后在輸出,因此屏幕上輸出5轉(zhuǎn)向表達(dá)式3,執(zhí)行y-, y=y-1=5-1=4。循環(huán)條件y0成立,進(jìn)入第4次
36、循環(huán)第4次循環(huán)執(zhí)行if語句。4%3不為0,if語句的條件表達(dá)式不成立,不執(zhí)行printf(%d”,- -y)轉(zhuǎn)向表達(dá)式3,執(zhí)行y-, y=4-1=3。循環(huán)條件y0成立,進(jìn)入第5次循環(huán)第5次循環(huán)執(zhí)行if語句。3%3=0,if語句的條件表達(dá)式成立,執(zhí)行printf(%d”,- -y),即y先自減1變?yōu)?,然后在輸出,因此屏幕上輸出2轉(zhuǎn)向表達(dá)式3,執(zhí)行y-, y=y-1=2-1=1。循環(huán)條件y0成立,進(jìn)入第5次循環(huán)第6次循環(huán)執(zhí)行if語句。1%3不為0,if語句的條件表達(dá)式不成立,不執(zhí)行printf(%d”,- -y)轉(zhuǎn)向表達(dá)式3,執(zhí)行y-, y=1-1=0。循環(huán)條件y0不成立,循環(huán)結(jié)束。18. #i
37、nclude main() int i,sum=0; i=1;do sum=sum+i; i+; while(i=10);printf(“%d”,sum);運(yùn)行結(jié)果為: 5519.#include #define N 4main() int i; int x1=1,x2=2;printf(n);for(i=1;i=N;i+) printf(%4d%4d,x1,x2);if(i%2=0) printf(n);x1=x1+x2;x2=x2+x1;運(yùn)行結(jié)果為:1 2 3 58 13 21 34此題 首先為整型變量賦初值x1=1,x2=2表達(dá)式1為i=1,表達(dá)式2(循環(huán)條件)為i=N即i=4,表達(dá)式3
38、為i+循環(huán)變量初值i為1,循環(huán)條件(即表達(dá)式2)i=4成立,進(jìn)入第1次循環(huán)第1次循環(huán)執(zhí)行printf(%4d%4d,x1,x2);因此屏幕上輸出1 2執(zhí)行if語句。1%2不為0,if語句的條件表達(dá)式不成立,不執(zhí)行printf(n);執(zhí)行x1=x1+x2=1+2=3;此時(shí)x1中的值已變?yōu)?執(zhí)行x2=x2+x1=2+3=5。轉(zhuǎn)向表達(dá)式3,執(zhí)行i+, i為2。循環(huán)條件i=4成立,進(jìn)入第2次循環(huán)第2次循環(huán)執(zhí)行printf(%4d%4d,x1,x2);因此屏幕上輸出3 5執(zhí)行if語句。2%2=0,if語句的條件表達(dá)式成立,執(zhí)行printf(n);換行執(zhí)行x1=x1+x2=3+5=8;此時(shí)x1中的值已變?yōu)?/p>
39、8執(zhí)行x2=x2+x1=5+8=13。轉(zhuǎn)向表達(dá)式3,執(zhí)行i+, i為3。循環(huán)條件i=4成立,進(jìn)入第3次循環(huán)第3次循環(huán)執(zhí)行printf(%4d%4d,x1,x2);因此屏幕上輸出8 13執(zhí)行if語句。3%2不為0,if語句的條件表達(dá)式不成立,不執(zhí)行printf(n);執(zhí)行x1=x1+x2=8+13=21;此時(shí)x1中的值已變?yōu)?1執(zhí)行x2=x2+x1=21+13=34。轉(zhuǎn)向表達(dá)式3,執(zhí)行i+, i為4。循環(huán)條件i=4成立,進(jìn)入第4次循環(huán)第2次循環(huán)執(zhí)行printf(%4d%4d,x1,x2);因此屏幕上輸出21 34執(zhí)行if語句。4%2=0,if語句的條件表達(dá)式成立,執(zhí)行printf(n);換行執(zhí)行
40、x1=x1+x2=21+34=55;此時(shí)x1中的值已變?yōu)?5執(zhí)行x2=x2+x1=34+55=89。轉(zhuǎn)向表達(dá)式3,執(zhí)行i+, i為5。循環(huán)條件i=4不成立,結(jié)束循環(huán)20#include main( ) int x, y; for(x=30, y=0; x=10, y10; x-, y+) x/=2, y+=2; printf(“x=%d,y=%dn”,x,y);運(yùn)行結(jié)果為:x=0,y=1221. #include #define N 4main( ) int i,j; for(i=1;i=N;i+) for(j=1;ji;j+) printf( ); printf(*); printf(n);
41、運(yùn)行結(jié)果為:* * *詳見教材P41符號(hào)常量用宏處理指令定義符號(hào)常量N為4,在編譯過程中,遇到N即視為整數(shù)4。外層for循環(huán),表達(dá)式1為i=1,表達(dá)式2(循環(huán)條件)為i=N,表達(dá)式3為 i+內(nèi)層for循環(huán),表達(dá)式1為j=1,表達(dá)式2(循環(huán)條件)為ji, 表達(dá)式3為j+首先計(jì)算外層循環(huán)的表達(dá)式1,i為1,使得循環(huán)條件i=4成立,進(jìn)入外層for循環(huán)體外層for循環(huán)第1次 此時(shí)i為1內(nèi)層循環(huán)j=1,使得循環(huán)條件ji不成立,因此不執(zhí)行內(nèi)層循環(huán)體(不輸出空格)執(zhí)行printf(*);執(zhí)行printf(n);換行至此外層循環(huán)體執(zhí)行完,計(jì)算外層循環(huán)的表達(dá)式3,i+,此時(shí)i為2. 使得循環(huán)條件i=4成立,再次進(jìn)入外層for循環(huán)體外層for循環(huán)第2次 此時(shí)i為2內(nèi)層循環(huán)j=1,使得循環(huán)條件ji成立第1次執(zhí)行內(nèi)層循環(huán)體printf( );執(zhí)行內(nèi)層循環(huán)表達(dá)式3,j+為2,ji不成立,跳出內(nèi)層循環(huán)執(zhí)行printf(*);執(zhí)行printf(n);換行至此外層循環(huán)體執(zhí)行完,計(jì)算外層循環(huán)的表達(dá)式3,i+,此時(shí)i為3. 使得循環(huán)
- 溫馨提示:
1: 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
2: 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
3.本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
5. 裝配圖網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 110中國人民警察節(jié)(筑牢忠誠警魂感受別樣警彩)
- 2025正字當(dāng)頭廉字入心爭當(dāng)公安隊(duì)伍鐵軍
- XX國企干部警示教育片觀后感筑牢信仰之基堅(jiān)守廉潔底線
- 2025做擔(dān)當(dāng)時(shí)代大任的中國青年P(guān)PT青年思想教育微黨課
- 2025新年工作部署會(huì)圍繞六個(gè)干字提要求
- XX地區(qū)中小學(xué)期末考試經(jīng)驗(yàn)總結(jié)(認(rèn)真復(fù)習(xí)輕松應(yīng)考)
- 支部書記上黨課筑牢清廉信念為高質(zhì)量發(fā)展?fàn)I造風(fēng)清氣正的環(huán)境
- 冬季消防安全知識(shí)培訓(xùn)冬季用電防火安全
- 2025加強(qiáng)政治引領(lǐng)(政治引領(lǐng)是現(xiàn)代政黨的重要功能)
- 主播直播培訓(xùn)直播技巧與方法
- 2025六廉六進(jìn)持續(xù)涵養(yǎng)良好政治生態(tài)
- 員工職業(yè)生涯規(guī)劃方案制定個(gè)人職業(yè)生涯規(guī)劃
- 2024年XX地區(qū)黨建引領(lǐng)鄉(xiāng)村振興工作總結(jié)
- XX中小學(xué)期末考試經(jīng)驗(yàn)總結(jié)(認(rèn)真復(fù)習(xí)輕松應(yīng)考)
- 幼兒園期末家長會(huì)長長的路慢慢地走