專升本C語言歷考試題及答案.doc
《專升本C語言歷考試題及答案.doc》由會員分享,可在線閱讀,更多相關《專升本C語言歷考試題及答案.doc(93頁珍藏版)》請在裝配圖網上搜索。
1、專升本C語言歷年考試題及答案(1) 程序設計語言的發(fā)展 1、機器語言 2、匯編語言 3、面向過程的語言 4、面向對象的程序設計語言(二) C程序設計語言的執(zhí)行過程1、編輯 2、編譯 3、連接 4、執(zhí)行(三) 用庫函數組裝C程序例1:計算2.1715的正弦值。#include “math.h”main( )float a; /*定義a為實型變量*/a=sin(2.1715); /*調用sin函數*/printf(“%fn”,a); /*調用printf函數,輸出a的值*/詳解:1、在本例中用到的sin函數稱為數學函數,它是為了用戶使用方便,由一批廠家開發(fā)編寫的函數,并不是C語言的一部分。在使用數
2、學函數時,往往要用到函數執(zhí)行時所需的一些信息(例如宏定義),這些信息包含在“math.h”中。因此在程序開頭用#include “math.h”將有關的標頭文件包括到程序中。2、一個C語言源程序文件由一個或多個函數組成,C語言的基本組成單位是函數。一個完整的C語言程序有且只有一個稱為主函數的main函數,程序總是從main函數開始執(zhí)行,調用其它函數后再回到main函數,在main函數中結束整個程序的運行。3、main是函數名稱,沒有參數可以不寫,但圓括號不能省略,main()后面有一對花括號,花括號內的部分稱為函數體,main函數可以在程序的任意位置。4、C規(guī)定每個語句以分號(;)結束,分號是
3、語句不可缺少的組成部分,每行中可以寫多條語句。5、/*與*/之間為注釋信息,對程序運行結果不發(fā)生影響,也不被編譯,注釋說明可以放在語句的任意位置。6、float a;此語句是把a定義為一個實型變量。7、C語言本身沒有輸入、輸出語句,本例使用prinft函數輸出數據。prinft函數的括號內包括兩部分內容:雙引號內的部分、雙引號外的部分。雙引號內的部分是“格式字符串”,用于指定輸出雙引號外的變量的打印格式。此例中雙引號中有一個”%f”,它是輸出一個保留小數點后6位數字的格式字符,小數點前的位數不指定。二、練習(一) 選擇題1、以下敘述正確的是_C_。(A)在C程序中,main函數必須位于程序的最
4、前面(B)C程序的每行中只能寫一條語句(C)C語言本身沒有輸入輸出語句(D)在對一個C程序進行編譯的過程中,可發(fā)現注釋中的拼寫錯誤2、C語言規(guī)定:在一個源程序中,main函數的位置_C_。(A)必須在最開始(B)必須在系統(tǒng)調用庫函數的后面(C)可以任意(D)必須在最后3、一個C語言程序是由_B。(A)一個主程序和若干子程序組成(B)函數組成(C)若干過程組成(D)若干子程序組成4、一個C程序的執(zhí)行是從A_。(A)本程序的main函數開始,到main函數結束(B)本程序文件的第一個函數開始,到本程序文件的最后一個函數結束(C)本程序的main函數開始,到本程序文件的最后一個函數結束(D)本程序文
5、件的第一個函數開始,到本程序main函數結束5、以下敘述不正確的是_D_。 (A)一個C源程序可由一個或多個函數組成(B)一個C源程序必須包含一個main函數(C)C程序的基本組成單位是函數(D)在C程序中,注釋說明只能位于一條語句后面(二) 填空題: 1、一個C源程序中至少包括一個 _main函數_。2、在一個C源程序中,注釋部分兩側的分界符分別為_/*_和_*/_。 第二章 數據描述與基本操作一、主要知識點(一) C的基本數據類型節(jié) 短整型(short) 整型 整型 (int) 基本類型 字符型(char) 長整型 (long)實型(浮點型) 單精度型 (float)枚舉類型 雙精度型 (
6、double)數據類型 構造類型 數組類型 結構類型(struct) 指針類型 共用類型(union) 空類型(void) 文件類型(FILE)(二) 常量和符號常量1、常量定義:在程序運行過程中,其值不能被改變的量稱為常量。常量常區(qū)分不同的類型,如12、0、-3為整型常量,a、D為字符常量。2、符號常量:用一個標識符代表一個常量的,稱為符號常量,即標識符形式的常量。常量不同于變量,它的值在作用域內不能改變,也不能再被賦值。例1:已知商品的單價及數量求商品的總價值。#define PRICE 30 main( ) int num=10,total; total=num*PRICE;printf
7、(“total=%d”,total);輸出結果:total=300詳解:1、程序中用#define命令行定義PRICE代表常量30,此后凡在此文件中出現的PRICE都代表30,可以和常量一樣進行運算。2、符號常量不同于變量,它的值在其作用域內不能改變,也不能再被賦值。如再用以下賦值語句給PRICE賦值:PRICE=40;是錯誤的。(三) 變量1、變量定義:其值可以改變的量稱為變量。2、標識符的命名規(guī)范和其它高級語言一樣,用來標識變量名、符號常量名、函數名、數組名、類型名、文件名的有效字符序列稱為標識符,語言中的標識符命名規(guī)范為:變量名只能由字母、數字和下劃線三種字符組成,且第一個字符必須為字母
8、或下劃線。C語言中標識符的長度(字符個數)無統(tǒng)一規(guī)定,隨系統(tǒng)而不同。許多系統(tǒng)(如IBM PC的MS C)取前7個字符,假如程序中出現的變量名長度大于7個字符,則只有前面7個字符有效,后面的不被識別。語言有32個關鍵字(例如if、else、while)它們已有專門含義,不應用采用與它們同名的變量名。C語言將大寫字母和小寫字母認為是兩個不同字。例2:在下列符號中,可以選用哪些作變量名?哪些不可以? a3B 3aB +a -b *x $ _b5_ if next_ day e_2 OK? integer MAXNUMBER i*j答案:_b5_ a3B next_ day e_2 MAXNUMBER
9、可作變量名,其它的作變量名不可以。詳解:MAXNUMBER可作變量名。習慣上符號常量名用大寫,變量名用小寫以示區(qū)別,但大寫字母作變量名并無錯誤。if、integer屬于保留字,保留字不可作變量名。 +a -b *x $ OK? i*j不可作變量名,因為變量名只能由字母、數字和下劃線三種字符組成。3aB不可作變量名,因為變量名的第一個字母必須為字母或下劃線。(四) 整型數據1、整型常量整型常量即整常數。C語言整常數可用以下三種表示形式。十進制表示。如231、-56.478八進制表示。以0開頭的數是八進制數。如0123即(123)8=1*82+2*81+3*80=64+16+3=83。十六進制表示
10、。以0 x開頭的數是16進制。如0 x123即(123)16=1*162+2*161+3*160=256+32+3=291。2、整型變量整型變量分為:基本型、短整型、長整型、和無符號型四種?;拘停詉nt表示短整型,以short int表示或以short表示長整型,以long int表示,或以long表示無符號型,存儲單元中全部二進制位(bit)用作存放數本身,而不包括符號。無符號型中又分為無符號整型、無符號短整型和無符號長整型,分別以unsigned int 、unsigned short 和unsigned long表示。3、整型數據的取值范圍C標準沒有具體規(guī)定各類型所占內存字節(jié)數,各種
11、機器處理上有所不同,以IBM PC為例,數的范圍如表2.1所示。表2.1所占位數數的范圍Int16-3276832767 即-215(215-1)shortint16-3276832767 即-215(215-1)Longint32-21474836482147483647 即-231(231-1)Unsignedint16065535 即0(216-1)Unsigned short16065535 即0(216-1)Unsigned long3204294967295 即0(232-1)4、整型常量的分類一個整常量,如果其值在-3276832767范圍內,認為它是int型,它可以賦值給int
12、型和long int型變量。一個整常量,如果其值超過了上述范圍,而在-21474836482147483647范圍內,則認為它是long int型,可以將它賦值給一個long int型變量。如果某一計算機系統(tǒng)的C版本確定的short int與int型在內存中占據的長度相同,則一個int型的常量出同時一個short int型常量。常量中無unsigned型。但一個非負值的整常量可以賦值給unsigned型整變量,只要它的范圍不超過變量的取值范圍即可。例如:將50000賦給一個unsigned int型變量是可以的,而將70000賦給它是不行的(溢出)。在一個整常量后面加一個字母l或L,則認為是l
13、ong int型常量。(五) 實型數據1、實型常量實數在C語言中又稱為浮點數。實數有兩種表示形式:十進制形式。它由數字和小數點組成(注意必須有小數點)。例如:0.123、.123、123.0、0.0都是十進制數形式。指數形式。如123.56e4或123.56E4都代表123.56*104。但字母e(或E)之前必須有數字,e后面指數必須為整數。例如:e3、2.1e3.5、.e3、e等都不是合法的指數形式。例3:下面四個選項中,均是不合法的浮點數的選項是_。(A)160. 0.12 e3 (B)123 2e4.2 .e5(C)-.18 123e4 0.0 (D)-.e3 .234 1e3答案:B詳
14、解:160. 0.12 -.18 123e4 0.0 .234 1e3是實數的十進制形式或指數形式。e3 2e4.2 .e5 -.e3不是正確的指數形式。因為正確的字母e(或E)之前必須有數字,e后面指數必須為整數。對于數據表示形式.e5以及-.e3,e前的.與-.不是有效的數字表示形式。123是整數形式。2、實型變量C實型變量分為單精度(float型)和雙精度(double型)兩類。在一般系統(tǒng)中,一個單精度型數據在內存中占4個字節(jié)(32位),一個double型數據占8個字節(jié)。一個單精度型變量能接收7位有效數字,一個double型變量能接收17位有效數字,數值的范圍隨機器系統(tǒng)而異。在IBM P
15、C中,單精度實數的范圍約為(3.4E10-383.4E1038),雙精度實數的范圍約為(1.7E10-3081.710308)。例4:main( ) float a; a=111111.666666; printf(“%f”,a); 輸出結果:111111.640621詳解:一個實型常量不分float型和double型。一個實型常量可以賦給一個float型或double型變量。根據變量的類型截取實型常量中相應的有效位數字。由于float型變量只能接收7位有效數字,因此在把111111.666666賦給a時,a只接收了111111.6,由于輸出函數printf中的%f格式表示輸出小數點后的6位小
16、數,所以111111.6后的40621屬于無意義數字。如果a改為double型,則能全部接收上述12位數字。(六) 字符型數據1、字符常量:普通形式的字符常量:用引號(即撇號)括起來的一個字符,如a、D、$、?等都是字符常量。轉義符:以“”開頭的字符序列。常用的以“”開頭的特殊字符見表2.2表2.2字符形式功能n換行t橫向跳格v豎向跳格b退格r回車f走紙換頁反斜杠字符單引號字符ddd1到3位8進進制所代表的字符xhh1到2位16進制數所代表的字符例5:若有說明語句:char c=729;則變量c_。(A)包含1個字符 (B)包含2個字符(C)包含3個字符 (D)說明不合法答案:D詳解:”后可以
17、有1到3位8進制所代表的字符,本題中”后的”72”屬于8進制所代表的字符,而”9”則不屬于8進制位所代表的字符,則729中包含了兩個字符常量72和9。而字符常量是用引號(即撇號)括起來的一個字符,所以答案為D。2、字符變量字符變量是用來存放字符常量的存儲單元。3、字符數據在內存中的存儲形式將一個字符常量存放到一個字符變量中,實際上并不是把該字符本身存放到內存單元中去,而是將該字符的相應的ASCII碼值存放到存儲單元中去。例6:將小寫字母轉換成大寫字母main( ) char c1=a; c1=c1-32; printf(“%c”,c1);輸出結果:A詳解:a的ASCII碼為97,所以c1=a;
18、語句的功能是把97賦值給了c1。c1=c1-32;語句的功能是把97-32的值65賦值給c1。printf函數中的%c格式表示以字符方式輸出。ASCII碼值為65的字符為A,所以運行結果為:A(七) 字符串常量字符常量是用一對雙引號括起來的零個或多個字符序列。C規(guī)定以字符0作為字符串結束標志。所以字符串”a”實際上包含2個字符:a、0,因此下面的語句:c=”a”;把一個串賦值給一個字符變量c是錯誤的。例7:下面不正確的字符串常量是_。(A)abc (B)”1212” (C)”0” (D)” ”答案:A詳解:abc是用單引號引來的,所以abc不是正確的字符串常量。(八) 算術運算符和算術表達式1
19、、基本算術運算符C語言中有5個基本算術運算符:(加法運算符。如3+5、+3)(減法運算符。如5-2、-)(乘法運算符,如3*5)(除法運算符,如5/3,5.0/3)(求余運算符,要求%兩側均為整型數據)例8:在C語言中,要求運算數必須是整型的運算符是_。(A)/ (B)+ (C)!= (D)%答案:D詳解:對于%運算符來說,要求兩側均為整型數據,所以表達式3.5%2與3%2.0是錯誤的。例9:寫出下列程序的輸出結果main( ) printf(“%d,%dn”,5/3,5%3);printf(“%d,%dn”,-5/-3,-5%-3);printf(“%d,%dn”,-5/3,-5%3);pr
20、intf(“%d,%dn”,5/-3,5%-3);輸出結果:1,21,-2-1,-2-1,2詳解:兩個同號整數相除時結果為正整數,如5/3、-5/-3的結果值為1。兩個異號整數相除時結果為負整數,多數機器采取“向零取整”法,即-5/-3=-1,5/-3=-1,但如果參加運算的兩個數中有一個數為實數時結果為實數。對于求余(%)運算,運算結果與第一個數的符號相同。優(yōu)先級別:先*、/、%后+、運算量:雙元運算量,前后必須為整數。左右結合性:自左至右參預運算。2、自加自減運算符C語言中有4種形式的自加自減運算符:i (先使i加1后使用)i (先使用后使i加1)i (先使i減1后使用)i (先使用后使i
21、減1)優(yōu)先級別:高于算術運算。例10:若x和n均是int型變量,且x和n的初值均為5,則計算表達式后x的值為_,n的值為_。x+=n+答案:10 6詳解:根據優(yōu)先級別選運算表達式n+,因為n+是后綴表示形式,所以n先參預運算,再運算表達式x+=n,則x為10,最后n自加為6。例11:main( ) int x,y,m,n;x=2;y=2m=x+*5;n=+y*5;printf(“%d,%d,%d,%d”,x,y,m,n);輸出結果:3,3,10,15詳解:對于后綴來說是先使用后運算,所以m的值為x在自加以前的2*5得10賦值給m后,x自加變?yōu)?。對于前綴來說是先運算后使用,所以m的值為x在自加
22、以后的3*5得15賦值給n。 運算量:單元運算量,此運算量必須為變量,所以表達式5+、(x+y)+是錯誤的。左右結合性:自右至左參預運算。(九) 關系運算1、C語言提供的關系運算符有: (大于) =(大于或等于) (小于) =(小于或等于) =(等于)是 !=(不等于)2、優(yōu)先級別:關系運算符的優(yōu)先級別低于純算術類,高于賦值類。后兩個的優(yōu)先級小于前四個。如表達式a+bc+d完全等價于表達式(a+b)(c+d)。3、運算量:關系運算符是雙元運算符,整型、實型、字符都可以參預運算。4、左右結合性:從左向右的結合方向5、關于關系運算符的進一步說明:關系表達式的值是整型數0或1,故也可以將其看成一種整
23、型表達式。例如:int i=1,j=7,a;a=i+(j%4!=0);的執(zhí)行結果為:a的值為2。要說明x在區(qū)間a,b中,普通數學中使用表達式axb。但C語言中應寫成a=x&x278在數學上是不允許的,而在C中是允許的。按自左至右求解。字符數據的比較按其ASCII碼值進行。在判定兩個浮點數是否相等時,由于存儲上的誤差,會得出錯誤的結果。例如:1.0/3.0*3.0=1.0該表達式的值為0。(十) 邏輯運算1、C語言提供的邏輯運算符:&(邏輯與) |(邏輯或) !(邏輯非)2、優(yōu)先級別:&與|的優(yōu)先級別低于關系運算符,高于條件運算符,&的優(yōu)先級別高于|,!的優(yōu)先級別與自加運算符(+)、自減運算符(
24、-)同級。3、運算量:&和|是雙元運算符,!是單元運算符。例12:已知x=43,ch=A,y=0;則表達(x=y&chB&!y)的值是_。(A)0 (B)語法錯 (C)1 (D)“真”答案:C詳解:C語言不提供邏輯性數據“真”和“假”,在進行邏輯運算時,結果不是1就是0。4、左右結合性:&和|運算符的結合方向為自左至右,!的結合方向為自右至左。5、關于邏輯運算符的進一步說明:在一個&表達式中,若&的一端為0,則不必再計算另一端,該表達式的值肯定為0。在一個|表達式中,若|的一端為0,則不必再計算另一端,該表達式的值肯定為1。例13:寫出下面程序的輸出結果。 main( ) int x,y,z;
25、 x=y=z=0; +x&+y|+z; printf(“%d,%d,%d”,x,y,z); x=y=z=0; +x|+y&+z; printf(“%d,%d,%d”,x,y,z);輸出結果:1,1,01,0,0詳解:因為&的優(yōu)先級別高于|,所以表達式+x&+y|+z是一個或表達式,根據|的一端為0,則不必再計算另一端的原則,先計算表達式+x&+y的值為1,因為1或任何值都為1,所以表達式+z沒有運算,輸出結果為:1,1,0。表達式+x|+y&+z也是一個或表達式,同樣根據|的一端為0,則不必再計算另一端的原則,先計算表達式+z的值為1,因為1或任何值都為1,所以表達式+y&+z沒有運算,輸出結
26、果為:1,0,0。(十一) 賦值運算1、基本的賦值運算符:=(將賦值運算符右側的表達式賦給左側的變量)2、自反算術賦值運算符C語言中有5個基本自反算術賦值運算符:=(a=3 等價于a=a3)=(a=3 等價于a=a3)=(a=3 等價于a=a3)=(a=3 等價于a=a3)=(a=3 等價于a=a3)3、優(yōu)先級別:賦值運算符與自反算術賦值運算符屬于同等級別,低于條件運算符,高于逗號運算符。如對于表達式x%=y+3完全等價于x%=(y+3)。例14:若有以下定義,則能使值為3的表達式是_。Int k=7,x=12;(A)x%=(k%5) (B)x%=(k-k%5)(C)x%=k-k%5 (D)(
27、x%=k)-(k%=5)答案:D詳解:表達式(x%=k)-(k%=5)完全等價于(x=x%k)-(k=k%5)等價于5-2,此表達式的結果為3。4、運算量:雙元運算量,賦值運算符與自反算術賦值運算的第一個量必須為變量,且=前后必須為整型數據。如對于表達式a*3+=2是錯誤的。因為此表達式完全等價于(a*3)=(a*3)+2。5、左右結合性:自右至左參預運算。例15:若a是int型變量,且a的初值為6,則計算表達式后a的值為_。a+=a-=a*a答案:-60詳解:表達式從左向右運算,先計算表達式a=a-36后a為-30,再計算表達式a=a+a后a的值變?yōu)?60。(十二) 條件運算: 1、條件運算
28、符的基本形式及功能:條件運算是一種在兩個表達式的值中選擇一個的操作。它的一般形式為:e1?e2:e3它的操作過程為,若e1為真,則表達式的值為e2,若為假表達式的值為e3。2、優(yōu)先級別:低于邏輯運算,高于賦值運算。3、運算量:三元運算量,e1一般為算術表達式,e2、e3可以是任意類型的表達式,條件表達式的值的類型為e2與e3二者中類型較高的。例16:若有條件表達式(exp)?a+:b-,則以下表達式中能完全等價于表達式(exp)的是_。答案:exp!=0詳解:對于表達式e1?e2:e3 ,e1一般為算術表達式、邏輯表達式、關系表達式,結果為1(真)或0(假)。也可以為數值exp,結果為結果為非
29、0(真)或0(假)在本例中與exp完全等價的表達式是exp!=0。4、左右結合性:自右至左運算。 例17:以下程序的運行結果是_。 main() int k=4,a=3,b=2,c=1; printf(“%d”,ka?k:cb?c:a); 答案:1 詳解:條件表達式是從右向左運算,所以在本例中先計算表達式cb?c:a的值,把各數值代入此表達式的值為1。再計算表達式ka?k:1的值,因為km,則自動取n值,即保證n個字符正常輸出。f格式:用來輸出實數(包括單、雙精度),以小數形式輸出。有以下幾種用法:%f:不指定寬度,整數部分全部輸出并輸出6位小數。%m.nf:輸出共占m列,其中有n位小數,如數
30、值寬度小于m左端補空格。 %-m.nf:輸出共占n列,其中有n位小數,如數值寬度小于m右端補空格。 e格式:以指數形式輸出實數??捎靡韵滦问剑?e:數字部分(又稱尾數)輸出6位小數,指數部分占5位或4位。%m.ne和%-m.ne:m、n和”-”字符含義與前相同。此處n指數據的數字部分的小數位數,m表示整個輸出數據所占的寬度。g格式:自動選f格式或e格式中較短的一種輸出,且不輸出無意義的零。4、關于printf函數的進一步說明:如果想輸出字符“%”,則應該在“格式控制”字符串中用連續(xù)兩個%表示,如:printf(“%f%”,1.0/3);輸出0.333333%。(十六) scanf函數 scan
31、f函數可以用來輸入任何類型的多個數據。1、scanf函數的一般格式scanf(格式控制,地址表列)“格式控制”的含義同printf函數。普通字符即需要原樣輸入的字符。地址表列是指由若干個地址組成的表列,它們之間用“,”隔開。2、格式控制的完整格式:% * m l或h 格式字符格式字符與printf函數中的使用方式相同,以%d、%o、%x、%c、%s、%f、%e,無%u格式、%g格式??梢灾付ㄝ斎霐祿剂袑?,系統(tǒng)自動按它截取所需數據。如:scanf(“%3d%3d”,&a,&b);輸入:123456系統(tǒng)自動將123賦給a,456賦給b。%后的“*”附加說明符,用來表示跳過它相應的數據。例如:s
32、canf(“%2d%*3d%2d”,&a,&b);如果輸入如下信息:1234567。將12賦給a,67賦給b。第二個數據”345”被跳過不賦給任何變量。輸入數據時不能規(guī)定精度,例如:scanf(“%7.2f”,&a);是不合法的,不能企圖輸入:12345.67而使a的值為12345.67。3、輸入數據流分隔根據格式字符的含義從輸入流中取得數據,當輸入流中數據類型與格式字符要求不符時,就認為這一項結束。如:scanf(“%d%c%f”,&a,&b,&c);如果輸入如下信息:1234r1234.567則scanf函數在接收數據時發(fā)現”r”類型不匹配,于是把”1234”轉換成整型賦值給a,把”r”賦
33、給變量b,最后把”1234.567”轉換成實型數據賦給c。根據格式項中指定的域寬分隔出數據項。如語句:scanf(“%2d%3f%4f”,&a,&b,&c);如果輸入如下信息:123456789012345 則scanf函數在接收數據時根據域寬把12賦值給a,345賦值給b,6789賦值給c。隱示分隔符。空格、跳格符(t)、換行符(n)都是C語言認定的數據分隔符。顯示分隔符。在scanf函數的兩個格式說明項間有一個或多個普通字符,那么在輸入數據時,在兩個數據之間也必須以這一個或多個字符分隔。如語句:scanf(“a=%d,b=%f,c=%f”,&a,&b,&c);則輸入數據應該為: a=123
34、4,b=67.8,c=98.1234、關于scanf函數的進一步說明:scanf函數中的“格式控制”后面應當是變量地址,而不應是變量名。例如,如果a、b為整型變量,則scanf(“%d,%d”,a,b);是不對的,應將”a,b”改為”&a,&b”。如果在“格式控制”字符串中除了格式說明以外還有其它字符,則在輸入數據時應輸入與這些字符相同的字符。例如:scanf(“%d,%d”,&a,&b);輸入時應輸入:3,4。3與4之間的逗號應與scanf函數中的“格式控制”中的逗號相對應,輸入其它符號是不對的。在用“%c”格式輸入字符時,空格字符和轉義字符都作為有效字符輸入。scanf(“%c%c%c”,
35、&c1,&c2,&c3);如輸入:a b c 。字符a賦給c1,字符(空格) 賦給c2,字符b 賦給c3。5、scanf的停止與返回格式參數中的格式項用法-正常結束。發(fā)生格式項與輸入域不匹配時-不正常退出:(十七) getchar、putchar函數1、getchar函數getchar函數是從終端輸入一個字符。getchar函數沒有參數,其一般形式為:getchar( )。2、putchar函數putchar函數的作用是向終端輸出一個字符。二、練習(一)選擇題1、下面四個選項中,均是不合法的用戶標識符的選項是_。(A)A P_0 do (B)float la0 _a(C)b-a goto in
36、t (D)_123 temp INT2、若x,i,j和k都是int型變量,則計算下面表達式后,x的值為_。x=(i=4,j=16,k=32)(A)4 (B)16 (C)32 (D)523、下列四個選項中,均是不合法的整型常量的選項是_。(A)-0f1 -0 xffff 0011(B)-0 xcdf 017 12,3456(C)-018 999 5e2(D)-0 x48eg -068 03f4、下面四個選項中,均是合法浮點數的選項是_。(A)1e1 5e-9.4 03e2(B)-.60 12e-4 -8e5(C)123e 1.2e-.4 2e-1(D)-e3 .8e-4 5.e-0 5、下面四個
37、選項中,均是合法字符的選項是_。(A) xf (B) 017 n(C)018 f xab(D)0 101 xlf6、以下不正確的敘述是_。(A)在C程序中,逗號運算符的優(yōu)先級最低。(B)在C程序中,APH和aph是兩個不同的變量(C)若a和b類型相同,在計算機了賦值表達式a=b后,b的值不變。(D)當從鍵盤輸入數據時,對于整型變量只能輸入整型數值,對于實型變量只能輸入實型數據。第三章 C程序的流程設計一、算法1、算法的概念為解決某一個問題而采取的方法和步驟,就稱為算法。2、算法的性質有窮性:一個算法應包含有限的操作步驟一個初始:此動作序列只有一個初始動作確定性:算法中的每一個步驟都應當是確定性
38、的,僅有一個后繼動作。有一個或多個輸出:序列終止表示問題得到解答或問題沒有解答,沒有輸出的算法是沒有意義的。二、選擇型程序設計1、if 語句的形式 if(條件表達式) 語句 if(條件表達式) 語句1 else 語句 2 注意:if語句中的條件表達式一般為邏輯表達式或關系表達式,但也可以是任意的數值類型(包括整型、實型、字符型、指針類型),例如下列語句也是合法的。 if(a) printf(“%d” ,a);在if語句中,分號是語句的結束標志。在if和else后面可以只含一個內嵌的操作語句,也可以有多個操作語句,此時用花括號將幾個語句括起來成為一個復合語句。例1:以下不正確的if語句形式是(
39、)。A)if(xy&x!=y);B)if(x=y) x+=y;C)if(x!=y) scanf(“%d”,&x) else scanf(“%d”,&y);D)if(xy)z=x;x=y;y=z; 答案:x,y,z的值分別是:20 30 30 詳解:在此語句中,條件xy為假,所以只執(zhí)行x=y;y=z;兩條語句。例3、以下不正確的語句是( )A)if(xy);B)if(x=y)&(x!=0) x+=y;C)if(x!=y) scanf(“%d”,&x);D)if(xy)x+;y+;答案:D詳解:分號是語句結束的標志,y+的末尾無分號,所以y+不是合法的語句。2、if 的嵌套 if(條件1) if(
40、條件2) 語句1 else 語句2 else if(條件3) 語句3 else 語句4例4:以下程序的輸出結果是( )main( )int a=100,x=10,y=20,ok1=5,ok2=0;if(xy)if(y!=10)if (!ok1)a=1;else if(ok2) a=10; printf(“%dn”,a); 答案:100詳解:把10、20、5、0分別給變量x、y、ok1、ok2賦值,執(zhí)行條件語句后a值沒有改變,所以a值仍是原值100。3、switch結構switch語句是多分支選擇語句,其形式如下:switch(表達式)case 常量表達式1:語句1case 常量表達式2:語句2
41、default:語句n+1注意:1、switch后面括弧內的“表達式”,可以是整型表達式或字符型表達式,也可以枚舉型數據。2、當表達式的值與某一個case后面的常量表達式的值相等時,就執(zhí)行此case后面的語句,若所有的case中的常量表達式的值都沒有與表達式的值匹配的,就執(zhí)行default后面的語句。3、每一個case的常量表達式的值必須互不相同,否則就會出現互相矛盾的現象。4、執(zhí)行完一個case后面的語句后,流程控制轉移到下一個case繼續(xù)執(zhí)行,直到遇到break語句或執(zhí)行完為止。5、default可以放在case語句的后面,也可以放在case語句的前面。例5:運輸公司對用戶計算運費,距離越
42、遠,每公里運費越低。設每公里每噸貨物的基本運費為p,貨物重為w,距離為s,折扣為d,則總運費f計算公式為f=p*w*s(1-d),編寫程序。公里數s與折扣率d的標準如下:(此程序可用ifelse來完成,也可以用switch來完成)。s250km d=0250s500 d=0.05500s1000 d=0.0751000s2000 d=0.12000s3000 d=0.153000s d=0.2 main()int s;float p,w,d,f;printf(“請輸入每公里每噸貨物的基本運費”);scanf(“%f”,&p);printf(“請輸入貨物重”);scanf(“%f”,&w);pr
43、intf(“請輸入公里數”);scanf(“%f”,&s);switch(int)(s/250) case 0: d=0; break; case 1: d=0.05; break; case 2: case 3: d=0.075; break; case 4: case 5:case 6: case 7: d=0.1; break; case 8: case 9:case 10: case 11: d=0.15; break; default: d=0.2; f=p*w*s(1-d); printf(“基本運費是:%f”,f);詳解:1、多個case可共用一組執(zhí)行語句,必須寫成如下的形式:c
44、ase 4: case 5:case 6: case 7: d=0.1; break;case后面只能有一個常量,把上式改寫成case 4,5,6,7: d=0.1; break;的形式是錯誤的。2、switch后面括弧內的“表達式”必須是整型表達式或字符型表達式,也可以是枚舉型數據,對于swith來說,關鍵是把原始數據轉換為易表達的形式。例6:請讀以程序寫出程序的輸出結果。#includemain( ) int x=1,y=0,a=0,b=0; switch(x) case 1: switch(y) case 0: a+;break;case 1: b+;break; case 2: a+;
45、b+;break; printf(“a=%d,b=%d”,a,b);答案:a=2,b=1詳解:此程序是switch的嵌套結構,在此程序中break跳出內層switch結構,接著執(zhí)行外層switch的case 2后的語句。例7:寫出下面程序的運行結果是( )main()int i;for(i=1;i=5;i+) switch(i%5) case 0: printf(“*”); break; case 1: printf(“#”); break; default: printf(“n”); case 2: printf(“&”); 答案:#& & &*詳解:default可放在case語句的前面,
46、也可以放在case語句的后面,當i%5不等于0,1,2時,將執(zhí)行default后的語句printf(“n”);執(zhí)行完成后沒有break,將繼續(xù)執(zhí)行case 2后的語句printf(“&”);三、循環(huán)型程序設計1、while語句while語句用來實現”當型”循環(huán)結構,其一般形式如下:while(條件表達式) 循環(huán)體語句例11:設有程序段: int k=10; while(k=0) k=k-1; 循環(huán)體執(zhí)行( )次。 答案:0答案解析:在此程序的while結構中,條件表達式k=0的結果永遠為0即為假,所以循環(huán)執(zhí)行的次數為0。例12:下面程序段的運行結果是( )x=y=0; while(x3) br
47、eak; 循環(huán)執(zhí)行( )次答案:4答案解析:while結構中的條件表達式printf(“*”)的值為輸出數據的個數,在此例中,printf(“*”)的結果為1,即為真。2、do-while語句do-while語句的特點是先執(zhí)行循環(huán)體,然后判斷循環(huán)條件是否成立,其一般形式為:do循環(huán)體語句while(條件表達式); 例14、若有如下語句 int x=3; do printf(“%dn”,x-=2); while(-x);則上面程序段輸出結果是( )。答案:1 例15、以下程序段循環(huán)執(zhí)行幾次。x=-1;do x=x*x; while(!x);答案:1例16、下面程序的運行結果是( )main( )
48、int y=10;doy-; while(-y);printf(“%dn”,y-);答案:0 3、for語句C語言中的for語句使用最為靈活,不僅可以用于循環(huán)次數已經確定的情況,而且可以用于循環(huán)次數不確定而只給出循環(huán)結束條件的情況,它完全可以代替while語句,其一般形式為:for(表達式1;表達式2;表達式2) 語句說明:for語句一般形式中的“表達式1”可以省略,此時應for語句之前給循環(huán)變量賦初值。注意省略表達式1時,其后的分號不能省略。如果表達式2省略,即不判斷循環(huán)條件,循環(huán)無終止地進行下去。表達式3也可以省略,但此時程序設計者應另外設法保證循環(huán)正常結束。可以省略表達式1和表達式3,只有表達式2,即只給循環(huán)條件,在這種情況下,完全等同于while語句。3個表達式都可省略,如:for( ; ; ) 語句,相當于while(1) 語句,即不設初值,不判斷條件(認為表達式2為真值),循環(huán)變量不增值。無終止地執(zhí)行循環(huán)體。表達式1可以是
- 溫馨提示:
1: 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
2: 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯系上傳者。文件的所有權益歸上傳用戶所有。
3.本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
4. 未經權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
5. 裝配圖網僅提供信息存儲空間,僅對用戶上傳內容的表現方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
6. 下載文件中如有侵權或不適當內容,請與我們聯系,我們立即糾正。
7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。