




版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
第一章C語(yǔ)言概述
一、選擇題:
1、一個(gè)C程序的執(zhí)行是從(A)。
A本程序的main函數(shù)開始,到main函數(shù)結(jié)束
B本程序文件的第一個(gè)函數(shù)開始,到本程序文件的最后一個(gè)函數(shù)結(jié)束
C本程序的main函數(shù)開始,到本程序文件的最后一個(gè)函數(shù)結(jié)束
D本程序文件的第一個(gè)函數(shù)開始,到本程序main函數(shù)結(jié)束
2、在C語(yǔ)言中,每個(gè)語(yǔ)句必須以(D)結(jié)束。
A.回車符B.冒號(hào)C.逗號(hào)D.分號(hào)
3、C語(yǔ)言規(guī)定:在一個(gè)源程序中,main函數(shù)的位置(C)。
A.必須在最開始B.必須在系統(tǒng)調(diào)用的庫(kù)函數(shù)的后面
C.可以任意D.必須在最后
4、一個(gè)C語(yǔ)言程序是由(B)。
A.一個(gè)主程序和若干子程序組成B.函數(shù)組成
C.若干過程組成D.若干子程序組成
5、下列說(shuō)法中錯(cuò)誤的是(D)0
A.主函數(shù)可以分為兩個(gè)部分:主函數(shù)說(shuō)明部分和主函數(shù)體
B.主函數(shù)可以調(diào)用任何非主函數(shù)的其他函數(shù)
C.任何非主函數(shù)可以調(diào)用其他任何非主函數(shù)
D.程序可以從任何非主函數(shù)開始執(zhí)行
6、用C語(yǔ)言編寫的源文件經(jīng)過編譯,若沒有產(chǎn)生編譯錯(cuò)誤,則系統(tǒng)將(C)。
A.生成可執(zhí)行目標(biāo)文件B.生成目標(biāo)文件
C.輸出運(yùn)行結(jié)果D.自動(dòng)保存源文件
二、填空題:
1、C語(yǔ)言只有32個(gè)關(guān)鍵字和9種控制語(yǔ)句。
2、每個(gè)源程序有且只有一個(gè)main函數(shù),系統(tǒng)總是從該函數(shù)開始執(zhí)行C語(yǔ)言
程序。
3、C語(yǔ)言程序的注釋可以出現(xiàn)在程序中的任何地方,它總是以\*符號(hào)作
為開始標(biāo)記,以*/符號(hào)作為結(jié)束標(biāo)記。
4、C語(yǔ)言中,輸入操作是由庫(kù)函數(shù)scanf完成的,輸出操作是由庫(kù)函
數(shù)printf完成的。
5、系統(tǒng)默認(rèn)的C語(yǔ)言源程序文件的擴(kuò)展名是.c,經(jīng)過編譯后生成的目標(biāo)文
件的擴(kuò)展名是.obj,經(jīng)過連接后生成的可執(zhí)行文件的擴(kuò)展名是.exeo
6、C語(yǔ)言的標(biāo)識(shí)符只能由字母、數(shù)字和下劃線三種字符組成。
第三章數(shù)據(jù)類型、運(yùn)算符和表達(dá)式
一、選擇題:
1、以下選項(xiàng)中,不正確的C語(yǔ)言浮點(diǎn)型常量是(C)。
A.160.B.0.12C.2e4.2D.0.0
2、以下選項(xiàng)中,(D)是不正確的C語(yǔ)言字符型常量。
A.'a'B.'\x41'C.D."a"
3、在C語(yǔ)言中,字符型數(shù)據(jù)在計(jì)算機(jī)內(nèi)存中,以字符的(C)形式存儲(chǔ)。
A.原碼B.反碼C.ASCII碼D.BCD碼
4、若x、i、j和k都是int型變量,則計(jì)算下面表達(dá)式后,x的值是(C)。
x=(i=4,j=16,k=32)
A.4B.16C.32D.52
5、算術(shù)運(yùn)算符、賦值運(yùn)算符和關(guān)系運(yùn)算符的運(yùn)算優(yōu)先級(jí)按從高到低依次為(B)。
A.算術(shù)運(yùn)算、賦值運(yùn)算、關(guān)系運(yùn)算B.算術(shù)運(yùn)算、關(guān)系運(yùn)算、賦值運(yùn)算
C.關(guān)系運(yùn)算、賦值運(yùn)算、算術(shù)運(yùn)算D.關(guān)系運(yùn)算、算術(shù)運(yùn)算、賦值運(yùn)算
6、若有代數(shù)式,則不正確的C語(yǔ)言表達(dá)式是(C)。
A.a/b/c*e*3B.3*a*e/b/cC.3*a*e/b*cD.a*e/c/b*3
7、表達(dá)式!x||a==b等效于(D)。
A.!((x||a)==b)B.!(x||y)==bC.!(x||(a==b))D.(!x)||(a==b)
8、設(shè)整型變量m,n,a,b,c,d均為1,執(zhí)行(m=a>b)&&(n=c>d)后,m,n的值是
(A)o
A.0,0B.0,1C.1,0D.1,1
9、設(shè)有語(yǔ)句inta=3;,則執(zhí)行了語(yǔ)句a+=a-=a*=a;后,變量a的值是(B)。
A.3B.0C.9D.-12
10、在以下一-組運(yùn)算符中,優(yōu)先級(jí)最低的運(yùn)算符是(D)。
A.*B.!=C.+D.=
11、設(shè)整型變量i值為2,表達(dá)式(++i)+(++i)+(++i)的結(jié)果是(B)。
A.6B.12C.15D.表達(dá)式出錯(cuò)
12、若已定義x和y為double類型,則表達(dá)式x=l,y=x+3/2的值是(C)。
A.1B.2C,2.0D.2.5
13、sizeof(double)的結(jié)果值是(A)0
A.8B.4C.2D.出錯(cuò)
14、設(shè)a=l,b=2,c=3,d=4,則表達(dá)式:a<b?a:c<d?a:d的結(jié)果為(D)o
A.4B.3C.2D.1
15、設(shè)a為整型變量,不能正確表達(dá)數(shù)學(xué)關(guān)系:10<a<15的C語(yǔ)言表達(dá)式是(A)。
A.10<a<15B.a==111]a==12||a==13|a==14
C.a>10&&a<15D.!(a<=10)&&!(a>=15)
16、設(shè)f是實(shí)型變量,下列表達(dá)式中不是逗號(hào)表達(dá)式的是(D)o
A.f=3.2,1.0B.f>0,f<10C.f=2.0,f>0D.f=(3.2,1.0)
17、表達(dá)式18/4*sqrt(4.0)/8值的數(shù)據(jù)類型是(C)。
A.intB.floatC.doubleD.不確定
18、已知字母A的ASCH碼為十進(jìn)制數(shù)65,且c2為字符型,則執(zhí)行語(yǔ)句
C2=>A'+'6'-'3';后c2中的值是(A)。
A.DB.68C.不確定的值D.C
19、以下用戶標(biāo)識(shí)符中,合法的是(B)。
A.intB.nitC.123D.a+b
20、C語(yǔ)言中,要求運(yùn)算對(duì)象只能為整數(shù)的運(yùn)算符是(A)。
A.%B./C.>D.*
21、若有說(shuō)明語(yǔ)句:charc='\72';則變量c在內(nèi)存占用的字節(jié)數(shù)是(A)。
A.1B.2C.3D.4
22、字符串"ABC”在內(nèi)存占用的字節(jié)數(shù)是(B)。
A.3B.4C.6D.8
23、要為字符型變量a賦初值,下列語(yǔ)句中哪一個(gè)是正確的(B)。
A.chara=〃3〃;B.chara='3';C.chara=%;D.chara=*;
24、下列不正確的轉(zhuǎn)義字符是(C)。
A.\\B.\'C.074D.\0
二、填空題:
1、C語(yǔ)言中的邏輯值“真”是用1表示的,邏輯值“假”是用0表示的。
2、若x和n都是int型變量,且x的初值為12,n的初值為5,則計(jì)算表達(dá)式
x%=(n%=2)后x的值為0。
3、設(shè)c=,w),a=l,b=2,d=-5,則表達(dá)式'x'+l>c,'y'!=c+2,-a-5*b<=d+l,
b==a=2的值分別為1、0、1、1。
4、設(shè)floatx=2.5,y=4.7;inta=7;,表達(dá)式x+a%3*(int)(x+y)%2/4的值
為2.5。
5、判斷變量a、b的值均不為0的邏輯表達(dá)式為a!=0&&b!=0。
6、求解賦值表達(dá)式a=(b=10)%(c=6),表達(dá)式值、a、b、c的值依次
為4,4,10,6o
7、求解逗號(hào)表達(dá)式x=a=3,6*a后,表達(dá)式值、x、a的值依次為18,3,3。
8、數(shù)學(xué)式a/(b*c)的C語(yǔ)言表達(dá)式a/b/c。
三、編程題:
1、設(shè)長(zhǎng)方形的高為1.5,寬為2.3,編程求該長(zhǎng)方形的周長(zhǎng)和面積。
2、編寫一個(gè)程序,將大寫字母A轉(zhuǎn)換為小寫字母a。
1.
main()
{floatx=l.5,y=2.3;printf("areais%6.2f\n",x*y);}
2.
mainO
{charc=,A';printf("%d”,c+32);}
順序結(jié)構(gòu)答案
一、單項(xiàng)選擇題
AADABCCBBD
二、程序改錯(cuò)題
1.正確的程序?yàn)?/p>
#include"stdio.h〃
main()
{charc;
getchar(c);
putchar()\007,);/*鳴笛*/
putchar();
}
2.正確的程序?yàn)?/p>
main()
{inta,b,s,1;
scanf(〃%d,%d〃,&a,&b);
s=a*b;1=2*(a+b);
printf(,,l=%d,s=%d\n〃,1,s);
三、寫出程序運(yùn)行結(jié)果
1.68
2.x=4
y=ll
四、編程題
1.main()
{inta,b,c,sum;
floatave;
scanf("%d%d%d",&a,&b,&c);
sum=a+b+c;ave=sum/3.0;
printf(rtsum=%d,ave=%.2f\n”,sum,ave);
)
五、選做題
1.voidmain()
{floata,b,temp;
printf("inputaandb:〃);
scanf("%d,%dz/,&a,&b);
temp=a;a=b;b=temp;
printf(,za=%d,b=%d\n,z,a,b);
)
選擇結(jié)構(gòu)答案
一、單項(xiàng)選擇題
1.B2.A3.D4.C5.D6.B7.C
二、填空題
1.554
554
334
2.40
3.VeryGood
Good
VeryGood
Fail
Pass
Pass
三、閱讀程序,寫出運(yùn)行結(jié)果
1.10,4,3;
-1
3
6
1
四、程序設(shè)計(jì)題
1.main()
{inta,b,x,y;
scanf(u%d%d”,&a,&b);
x=a*a+b*b;
if(x>100)
{y=x/100;printf("%d",y);}
elseprintf(4<%dv,a+b);
)
2.if結(jié)構(gòu)
mainO
{floatt;charc;
printf("inputscore,maxas100:\n");
scanf(,&t);
if(t>=90)ch=,A';
elseif(t>=80)ch='B';
elseif(t>=70)ch='C';
elseif(t>=60)ch='D';
elsech='E';
printf("Grade二%d\n”,ch);
switch結(jié)構(gòu)
mainO
{floatt;charc;
printf("inputscore,maxas100:\n");
scanf(“%f”,&t);
switch(t/10)
{case10:
case9:ch='A';break;
case8:ch='B';break;
case7:ch='C';break;
case6:ch='D';break;
case5:ch=,E';
)
printf("Grade二%d\n",ch);
}
五、選做題
1.mainO
{inta,b,c,t;
scanf("%d%d%d”,&a,&b,&c);
if(a<b){t=a;a=b;b=t;}
if(a<c){t=a;a=c;c=t;}
if(b<c){t=b;b=c;c=t;}
printf(%d,%d\n”,a,b,c);
}
2.switch((s>0)&&(s<=10))
{case1:switch((s>=3)&&(s<=6))
{case1:x=2;break;
case0:switch(s>l)||(s>8))
{case1:x=3;break;
case0:x=l;break;
}
}break;
case0:x=0;break;
)
循環(huán)結(jié)構(gòu)答案
一、選擇題
1.B2.A3.A4.C5.A6.B7.A8.C9.D10.D
二、填空題
1.xlxl/2-2
2.ch=getchar()ch>=,A*&&ch<=*Z'
3.s=s+t*it=-t
三、閱讀下列程序,寫出程序運(yùn)行的輸出結(jié)果
1.852
2.8921
3.5
4.SUM=2468
四、程序改錯(cuò)
1.main()
{inti=200,n=0;/*n用來(lái)記錄每行已打印數(shù)的個(gè)數(shù)*/
while(i<=300)
{if(i%7==0)
{//break;
printf(“965d”,i);n=n+l;
if(n==5)/*滿5個(gè)換行*/
{printf("\n");n=0;}
)
i++;})
2).main()
{inti,s=0,t=l;
for(i=l;i<=7;i++)
{t=t*i;s=s+t;
printf(/,sum=%d\n//,s);
)
五、程序設(shè)計(jì)題
1.main()
{intx,g,s,b;
for(x=100;x<1000;x++)
{b=x/100;s=x%100/10;g=x%10;
if((g*g*g+s*s*s+b*b*b)==x)
printf(u%d\n,',x);}
)
2.main()
{inti,s=0,f=l;
for(i=2;i<80;i++)
{s=s+f*(i-l)/i;f=-f;}
printf(s=%f\n,>,s);
)
六、選做題
1.main()
{floats=0,m=2.0,n=l.0,p;
inti;
for(i=l;i<=20;i++)
{s=s+m/n;p=m;m=m+n;n=p;}
printf(s=%f\n,,,s);
2.ttinclude<stdio.h>
main()
{inti,j,k,s=l;
for(i=l;i<=20;i++)
for(j=l;j<=50;j++)
{k=100-i*5-j*2;
if(k>=0)
{printf("%2d%2d股d”,i,j,k);
s=s+1;
if(s%5==0)printf("\n”);
第7章數(shù)組習(xí)題
A卷
1.單項(xiàng)選擇題
(1)inta[4]={5,3,8,9};其中a[3]的值為()。D
A.5B.3C.8D.9
(2)以下4個(gè)字符串函數(shù)中,()所在的頭文件與其他3個(gè)不同。A
A.getsB.strcpyC.strlenD.strcmp
(3)以下4個(gè)數(shù)組定義中,()是錯(cuò)誤的。D
A.inta[7];B.#defineN5longb[N];C.charc[5];D.int
n,d[n];
(4)對(duì)字符數(shù)組進(jìn)行初始化,()形式是錯(cuò)誤。B
A.charcl[]={'1','2','3'};B.charc2[]=123;C.charc3[]={'1",
'2','3',''0'};D.charc4[]="123";
(5)在數(shù)組中,數(shù)組名表示()oA
A.數(shù)組第1個(gè)元素的首地址B.數(shù)組第2個(gè)元素的首地址
C.數(shù)組所有元素的首地址D.數(shù)組最后1個(gè)元素的首地址
(6)若有以下數(shù)組說(shuō)明,則數(shù)值最小的和最大的元素下標(biāo)分別是()oB
inta[12]={1,2,3,4,5,6,7,8,9,10,11,12);
A.1,12B.0,11C.1,11D.0,12
(7)若有以下說(shuō)明,則數(shù)值為4的表達(dá)式是()。D
inta[12]=[1,2,3,4,5,6,7,8,9,10,11,12};charc='a',d,g;
A.a[g-c]B.a[4]C.a['d'-'c']D.a['d'-c]
(8)設(shè)有定義:chars[12]="string”;則printf("%d\n",strlen(s));的
輸出是()oA
A.6B.7C.11D.12
(9)設(shè)有定義:chars[12]="string”;則printf("%d\n”,sizeof(s));的
輸出是()oD
A.6B.7C.11D.12
(10)合法的數(shù)組定義是()oA
A.chara[]="string”;B.inta[5]={0,1,2,3,4,5};C.chara=
"string”;D.chara[]={0,1,2,3,4,5)
(11)合法的數(shù)組定義是()。D
A.inta[3][]={0,1,2,3,4,5};B.inta[][3]={0,1,2,3,4);
C.inta[2][3]={0,1,2,3,4,5,6};D.inta[2][3]={0,1,2,3,4,5,};
(12)下列語(yǔ)句中,正確的是()oD
A.chara[3][]={'abc','1'};B.chara[][3]={'abc','1'};
C.chara⑶[]={'a,T};D.chara[][3]={"a〃,T};
(13)下列定義的字符數(shù)組中,輸出printf(級(jí)s\n〃,str[2]);的輸出是()。
C
staticstr⑶[20]={"basic","foxpro","windows"};
A.basicB.foxproC.windowsD.輸出語(yǔ)句出錯(cuò)
(14)下列各語(yǔ)句定義了數(shù)組,其中哪一個(gè)是不正確的()0C
A.chara[3][10]={"China","American","Asia"};B.int
x[2][2>{1,2,3,4};
C.floatx[2][]={1,2,4,6,8,10};D.intm[][3]={1,2,3,4,5,6};
(15)數(shù)組定義為inta[3][2]={l,2,3,4,5,6},值為6的數(shù)組元素是()。
B
A.a[3][2]B.C.a[l][2]D.a[2][3]
(16)下面的程序中哪一行有錯(cuò)誤()oD
#include<stdio.h>
mainO
floatarray[5]={0.0};〃第A行
inti;
for(i=0;i<5;i++)
scanf(〃%f〃,&array[i]);
for(i=l;i<5;i++)
array[0]=array[0]+array[i];〃第B行
printf(,/%f\n,/,array[0]);〃第C行
)
A.第A行B.第B行C.第C行D.沒有
(17)下面哪一項(xiàng)是不正確的字符串賦值或賦初值的方式()oC
A.char*str;str=〃string”;
B.charstr[7]={,s,,,t,,,r,,,i,,,n,,,g,};
C.charstrl[10];strl="string”;
D.charstrl口二〃string”,str2□二〃12345678〃;
(18)若有以下說(shuō)明和語(yǔ)句,則輸出結(jié)果是哪一項(xiàng)()oC
(strlen(s)為求字符串s的長(zhǎng)度的函數(shù))
chars[12]=//abook!z,;
printf(〃%d〃,strlen(s));
A.12B.8C.7D.11
(19)若有以下說(shuō)明和語(yǔ)句,則輸出結(jié)果是()。B
(strlen(s)為求字符串s的長(zhǎng)度的函數(shù))
charsp□=〃\t\v\\\0will\n〃;
printf("/d",strlen(sp));
A.14B.3C.9D.字符串中有非法字符
(20)若有以下說(shuō)明和語(yǔ)句,則輸出結(jié)果是()0C
charstr[]="\"c:\\abc.dat\"”;
printf(“*s",str);
A.字符串中有非法字符B.\"c:\\abc.dat\"C."c:\abc.dat"D.
“c:\\abc.dat”
2.填空題
(1)C語(yǔ)言中,數(shù)組的各元素必須具有相同的,元素的下標(biāo)下限
為,下標(biāo)必須是正整數(shù)、0、或者。但在程序執(zhí)行過程中,不檢
查元素下標(biāo)是否。
數(shù)據(jù)類型,0,符號(hào)常量,越界
(2)C語(yǔ)言中,數(shù)組在內(nèi)存中占一片的存儲(chǔ)區(qū),由代表它的首
地址。數(shù)組名是一個(gè)常量,不能對(duì)它進(jìn)行賦值運(yùn)算。連續(xù),數(shù)組名,地址
(3)執(zhí)行staticintb[5],a[][3]={1,2,3,4,5,6};后,b[4]=,a[l][2]
=o0,6
(4)設(shè)有定義語(yǔ)句staticinta[3][4]={{1},{2},{3}};則值
為,值為,的值為。2,0,0
(5)如定義語(yǔ)句為chara[]="windows",b[]="95";,語(yǔ)句
printfstrcat(a,b));的輸出結(jié)果為。Windows95
(6)根據(jù)以下說(shuō)明,寫出正確的說(shuō)明語(yǔ)句:men是一個(gè)有10個(gè)整型元素的數(shù)
組。
step是一個(gè)有4個(gè)實(shí)型元素的數(shù)組,元素值分別為1.9,-2.33,0,
20.6o
grid是一個(gè)二維數(shù)組,共有4行,10列整型元素。
intmesh[10];floatstep[4]={1.9,~2.33,0,20.6};intgrid[4][10];
(7)array是一個(gè)一維整形數(shù)組,有10個(gè)元素,前6個(gè)元素的初值是
9,4,7,49,32,-5,正確的說(shuō)明語(yǔ)句為:
。該數(shù)組下標(biāo)的取值范圍是從—到_(從小到大)。用scanf
函數(shù)輸入數(shù)組的第二個(gè)元素表示為:。用賦值語(yǔ)句把39存入
第一個(gè)元素表示為:。
把第六個(gè)和第四個(gè)元素之和存入第一個(gè)元素表示
為:。
intarray[10]=
{9,4,7,49,32,-5};09scanf&array[l]);array[0]=
39;array[0]=array[5]+array[3];
(8)寫出以下初始化數(shù)組的長(zhǎng)度:①intchn[3];數(shù)組chn的長(zhǎng)度為―。②float
isa[]={l.0,2.0,3.0,4.0,5.0);
數(shù)組isa的長(zhǎng)度為__o③intdoom[8];數(shù)組doom的長(zhǎng)度為___。④float
pci[4][2];數(shù)組pci的長(zhǎng)度為___o
⑤intast[3][3];數(shù)組ast的長(zhǎng)度為___。⑥intatt[3][4];數(shù)組att的長(zhǎng)度為
⑦floatdell口[3]={{1,4,7},{2,5},{3,6,9}};數(shù)組dell的長(zhǎng)度為
—o6201632182436
(9)若有以下整型的a數(shù)組,數(shù)組元素和它們得值如下所示:
數(shù)組元素:a[0]
a[l]a[2]a[3]a[4]a[5]a[6]a[7]a[8]a[9]
元素的值:941282107513
①請(qǐng)寫出對(duì)該數(shù)組的說(shuō)明,并賦以上初值。
②該數(shù)組的最小下標(biāo)值為一_,最大下標(biāo)值為
③寫出下面各式的值:a[a[9]]的值為__;a[a[4]+a[8]]的值為__
inta[10]={9,4,12,8,2,10,7,5,1,3);0988
(10)字符串"ab\n\\012/\\\"的長(zhǎng)度為―010
3.判斷題
(X)(1)C允許對(duì)數(shù)組的大小作動(dòng)態(tài)定義,即可用變量定義數(shù)組的大小。
(X)(2)字符數(shù)組不要求它的最后一個(gè)字符為‘\0',甚至可以不包含
<\0,O
(X)(3)數(shù)組定義inta[10];也可以寫成inta(10);。
(J)(4)在對(duì)全部數(shù)組元素賦初值時(shí),可以不指定數(shù)組長(zhǎng)度。
(X)(5)定義s為5X6(5行6歹U)的數(shù)組可寫成floata[5,6];
(J)(6)數(shù)組定義inta[10];表示數(shù)組名為a,此數(shù)組有10個(gè)元素。
(X)(7)數(shù)組定義inta[10];表示數(shù)組名為a,此數(shù)組有10個(gè)元素,第
10個(gè)元素為a[10]o
(J)(8)staticcharc[]={aabook"};與staticcharc[]="abook”;
等價(jià)。
(X)(9)staticcharc[]={'a','','b','o','o','k',''0'};與static
charc[]={'a'等價(jià)。
(X)(10)設(shè)已有說(shuō)明:staticcharcl[10],c2[10];下面程序片段是合法
的。cl={"book"};c2=cl;
4.程序填空題
(1)輸入20個(gè)數(shù),輸出它們的平均值,輸出與平均值之差的絕對(duì)值為最小的數(shù)
組元素。請(qǐng)?zhí)羁铡?/p>
Winclude<stdio.h>
voidmain()
floata[20],pjz=0,s,t;inti,k;
for(i=0;i<20;i++)pjz+=a[i];
s=fabs(a[0]-pjz);
for(i=l;i<20;i++)
if(fabs(a[i]-pjz)<s)
{
s=fabs(a[i]-pjz);t=a[i];
for(i=0;i<20;i++)scanf(“%f”,;pjz/=20;
printf(^%f,%f\nv,piz,t);
(2)以下程序以每行10個(gè)數(shù)據(jù)的形式輸出a數(shù)組,請(qǐng)?zhí)羁铡?/p>
voidmain()
(
inta[50],i;
printf(〃輸入50個(gè)整數(shù):〃);
for(i=0;i<50;i++)scanf(〃%d〃,);
for(i=l;i<=50;i++)
{if()
printf(/z%3d\n/z,);
printf(/z%3dz/,a[i-l]);
&a[i]i%10==0a[i-l]
(3)下面程序的功能是輸出數(shù)組s中最大元素的下標(biāo),請(qǐng)?zhí)羁铡?/p>
voidmain()
(
intk,p;
ints[]={l,-9,7,2,-10,3);
for(p=0,k=p;p<6;p++)
if(s[p]>s[k]);
printf(/,%d\n,/,k);
)
k=p
(4)這個(gè)程序輸入了20個(gè)數(shù)存放在一個(gè)數(shù)組中,并且輸出其中最大者與最小
者、20個(gè)數(shù)的和及它們的平均值。請(qǐng)?zhí)羁铡?/p>
voidmain()
(
chararray;
intmax,min,average,sum;
inti;
for(i=0;i<;i++)
printf(〃請(qǐng)輸入第%d個(gè)數(shù):〃,i+1);
scanf;
)
max=array[0];
min=array[0];
for(i=0;i<=;i++)
(
if(max<array[i])
if(min>array[i])
sum=;
)
average=;
printf("20個(gè)數(shù)中最大值是%d,〃,max);
printf("最小值是%d,〃,min);
printf(〃和是%d,〃,sum);
printf(〃平均值是%d.\n〃,average);
}
[20]
20
&array[i]
19
max=array[i];
min=array[i];
sum+array[i]
sum/20
B卷
5?閱讀程序,分析程序的功能。
(1)
ttinclude<stdio.h>
ttinclude<string.h>
voidmain()
(
chars[80];
inti;
for(i=0;i<80;i++)
(
s[i]=getchar();
if(sEi]==,\n,)break;
)
s[i]='\0';i=0;
while(s[i])putchar(s[i++]);
putchar('\n');
從鍵盤輸入一個(gè)字符串,并逐一輸出
(2)
#include<stdio.h>
Sinclude<string.h>
voidmain()
[
charstr[10][80],c[80];
inti;
for(i=0;i<10;i++)gets(str[i]);
strcpy(c,str[0]);
for(i=l;i<10;i++)if(strlen(c)<strlen(str[i]))strcpy(c,str[i]);
printf(〃%s\n〃,c);
printf(〃%d\n〃,strlen(c));
)
從鍵盤輸入若干字符串,找到其中最長(zhǎng)的一個(gè)輸出及它的長(zhǎng)度
(3)
#include<stdio.h>
ttinclude<string.h>
voidmain()
chara[10][80],c[80];
inti,j,k;
for(i=0;i<10;i++)gets(a[i]);
for(i=0;i<9;i++)
(
k=i;
for(j=i+l;j<10;j++)
if(strcmp(a[j],a[k])<0)k=j;
if(k!=i)
{strcpy(c,a[i]);strcpy(a[i],a[k]);strcpy(a[k],c);}
//字符串交換
)
for(i=0;i<10;i++)puts(a[i]);
)
從鍵盤輸入若干字符串,并將它們按大到小順序排好再輸出
(4)閱讀程序,寫出運(yùn)行結(jié)果
Sinclude<stdio.h>
voidmain()
(
inta[6]={12,4,17,25,27,16},b[6]={27,13,4,25,23,16},i,j;
for(i=0;i<6;i++)
for(j=0;j<6;j++)if(a[i]==b[j])break;
if(j<6)printf("%d
)
printf('\n");
)
4252716
(5)閱讀程序,寫出運(yùn)行結(jié)果。
Sinclude<stdio.h>
voidmain()
{
chara[8],temp;intj,k;
for(j=0;j<7;j++)a[j]-a+j;a[7]-\0f;
for(j=0;j<3;j++)
(
temp=a[6];
for(k=6;k>0;k--)a[k]=a[k-l];
a[0]=temp;
printf(〃%s\n〃,a);
gabcdef
fgabcde
efgabcd
(6)閱讀下列程序,寫出程序運(yùn)行的輸出結(jié)果。
Sinclude<stdio.h>
#include<string.h>
voidmain()
(
charstrl[]=〃*******〃;
for(inti=0;i<4;i++)
(
printf(zz%s\nz,,strl);
strl[i]=,,;
strl[strlen(strl)-l]=,\0?;
)
)
***
*
(7)該程序的運(yùn)行結(jié)果是:min=,m=
voidmainO
floatarray[4][3]={
{3.4,-5.6,56.7},
{56.8,999.,-.0123},
{0.45,-5.77,123.5},
{43.4,0,111.2}
};
inti,j;
intmin;
intm,n;
min=array[0][0];
m=0;n=0;
for(i=0;i<3;i++)
for(j=0;j<4;j++)
if(min>array[i][j])
{
min=array[i][j];
m=i;n=j;
)
printf(/zmin=%d,m=%d,n=%d\n〃,min,m,n);
)
-5.7721
(8)寫出下面這個(gè)程序的輸出結(jié)果:
voidmain()
(
charstr[]=/zABCDEFGHIJKL,z;
printf("%s\n",str);屏幕上顯示
printf(z,%s\nz/,&str[4]);屏幕上顯示
str[2]=str[5];
printf(級(jí)s\n”,str);屏幕上顯示
str[9]=,\0";
printf(線s\n”,str);屏幕上顯示
)
ABCDEFGHIJKL
EFGHIJKL
ABFDEFGHIJKL
ABFDEFGHI
(9)讀懂下面的程序并填空。
voidmain()
(
charstr[80];
inti=0;
gets(str);
while(str[i]!=0)
if(str[i]>=,a'&&str<=,z')
str[i]-=32;
i++;
)
puts(str);
}
程序運(yùn)行時(shí)如果輸入upcase,屏幕顯示
程序運(yùn)行時(shí)如果輸入AalBb2Cc3,屏幕顯示
UPCASE
AA1BB2CC
第8章函數(shù)習(xí)題
A卷
1.單項(xiàng)選擇題
(DC語(yǔ)言總是從函數(shù)開始執(zhí)行。A
A.mainB.處于最前的C.處于最后的D.隨機(jī)選一個(gè)
⑵函數(shù)在定義時(shí),省略函數(shù)類型說(shuō)明符,則該函數(shù)值的類型為。A
A.intB.floatC.longD.double
⑵以下函數(shù),真正地沒有返回值。B
A.inta(){inta=2;return(a);}B.voidb(){printf("c");}
C.inta(){inta=2;returna;}D.以上都是
(3)在C語(yǔ)言中,有關(guān)函數(shù)的說(shuō)法,以下正確的是A
A.函數(shù)可嵌套定義,也可嵌套調(diào)用B.函數(shù)可嵌套定義,但不可嵌套調(diào)
用
C.函數(shù)不可嵌套定義,但可嵌套調(diào)用D.函數(shù)不可嵌套定義,也不可嵌套
調(diào)用
(4)以下函數(shù)調(diào)用語(yǔ)句中,含有實(shí)參的個(gè)數(shù)為。C
fun((2,3),(4,5+6,7));
1B.2C.5D.6
(5)函數(shù)調(diào)用可以在。D
A.函數(shù)表達(dá)式中B.函數(shù)語(yǔ)句中C.函數(shù)參數(shù)中D.以上
都是
(6)被調(diào)函數(shù)返回給主調(diào)函數(shù)的值稱為C
A.形參B.實(shí)參C.返回值D.參數(shù)
(7),可以不進(jìn)行函數(shù)類型說(shuō)明。D
A.被調(diào)函數(shù)的返回值是整型或字符型時(shí)B.被調(diào)函數(shù)的定義在主調(diào)函數(shù)
定義之前時(shí)
C.在所有函數(shù)定義前,已在函數(shù)外預(yù)先說(shuō)明了被調(diào)函數(shù)類型D.以上都是
(8)被調(diào)函數(shù)通過語(yǔ)句,將值返回給主調(diào)函數(shù)。D
A.ifB.forC.whileD.return
⑼被調(diào)函數(shù)調(diào)用結(jié)束后,返回到。D
A.主調(diào)函數(shù)中該被調(diào)函數(shù)調(diào)用語(yǔ)句處
B.主函數(shù)中該被調(diào)函數(shù)調(diào)用語(yǔ)句處
C.主調(diào)函數(shù)中該被調(diào)函數(shù)調(diào)用語(yǔ)句的前一語(yǔ)句
D.主調(diào)函數(shù)中該被調(diào)函數(shù)調(diào)用語(yǔ)句的后一語(yǔ)句
(10)以下對(duì)C語(yǔ)言函數(shù)的有關(guān)描述中,正確的是。A
A.在C中,調(diào)用函數(shù)時(shí),只能把實(shí)參的值傳送給形參,形參的值不能傳送給實(shí)
參
B.C函數(shù)既可以嵌套定義乂可遞歸調(diào)用
C.函數(shù)必須有返回值,否則不能使用函數(shù)
D.C程序中有調(diào)用關(guān)系的所有函數(shù)必須放在同一個(gè)源程序文件中
(1DC語(yǔ)言中函數(shù)的隱含存儲(chǔ)類型是。C
A.autoB.staticC.externD.無(wú)存儲(chǔ)類型
(12)能把函數(shù)處理結(jié)果的兩個(gè)數(shù)據(jù)返回給主調(diào)函數(shù),在下面的方法中不正確的
是。A
A.return這兩個(gè)數(shù)B.形參用兩個(gè)元素的數(shù)組
C.形參用兩個(gè)這種數(shù)據(jù)類型的指針D.用兩個(gè)全局變量
(13)C語(yǔ)言可執(zhí)行程序從什么地方開始執(zhí)行()oC
A.程序中第一條可執(zhí)行語(yǔ)句B.程序中第一個(gè)函數(shù)
C.程序中的main函數(shù)D.包含文件中的第一個(gè)函數(shù)
(14)有一個(gè)函數(shù)原型如下所示,則該函數(shù)的返回類型為()。C
abc(floatx,floaty);
A.voidB.doubleC.intD.float
2.填空題
(1)變量的作用域主要取決于變量,變量的生存期既取決于變
量,又取決于變量。所處的位置,所處的位置,存儲(chǔ)類型
(2)說(shuō)明變量時(shí),若省略存儲(chǔ)類型符,系統(tǒng)默認(rèn)其為存儲(chǔ)類別,該存儲(chǔ)
類別的類型符為:。動(dòng)態(tài),auto
(3)靜態(tài)型局部變量的作用域是,生存期是。它所在的局部,
整個(gè)程序
(4)函數(shù)中的形參和調(diào)用時(shí)的實(shí)參都是數(shù)組名時(shí),傳遞方式為,都是變
量時(shí),傳遞方式為。址傳遞,值傳遞
(5)函數(shù)的形式參數(shù)的作用域?yàn)?,全局的外部變量和函?shù)體內(nèi)定義的局
部變量重名時(shí),變量?jī)?yōu)先。該函數(shù)中,局部
(6)若自定義函數(shù)要求返回一個(gè)值,則應(yīng)在該函數(shù)體中有一條語(yǔ)句,若
自定義函數(shù)要求不返回一個(gè)值,則應(yīng)在該函數(shù)說(shuō)明時(shí)加一個(gè)類型說(shuō)明
符oreturn,void
(7)若函數(shù)的形式參數(shù)是指針類型,則實(shí)參可以是或。指針,
數(shù)組名
(8)函數(shù)的參數(shù)為char*類型時(shí),形參與實(shí)參結(jié)合的傳遞方式為。址
傳遞
(9)函數(shù)的實(shí)參為常量時(shí),形參與實(shí)參結(jié)合的傳遞方式為。值傳遞
(10)下面這個(gè)函數(shù)的功能是求兩個(gè)整數(shù)的積,并通過形參傳回結(jié)果,請(qǐng)?zhí)羁铡?/p>
intintint**result
voidmul(__x,___y,result)
=x*y;
3.判斷題
(X)(1)函數(shù)說(shuō)明指的是在程序中設(shè)定一個(gè)函數(shù)模塊。
(V)(2)形參只有在被調(diào)用時(shí)才分配存儲(chǔ)空間。
(X)(3)在C的函數(shù)中,最好使用全局變量。
(X)(4)在調(diào)用函數(shù)時(shí),實(shí)參傳值給形參,調(diào)用結(jié)束時(shí),形參值傳給實(shí)參。
(J)(5)所有函數(shù)定義都是并行的,相互獨(dú)立的。
(X)(6)函數(shù)的隱含存儲(chǔ)類型是extern。
(X)(7)形參可以是常量、變量或表達(dá)式。
X)(8)函數(shù)調(diào)用可以作為一個(gè)函數(shù)的形參。
(V)(9)C語(yǔ)言規(guī)定,實(shí)參應(yīng)與其對(duì)應(yīng)的形參類型一致。
(X)(10)定義函數(shù)時(shí),形參的類型說(shuō)明可以放在函數(shù)體內(nèi)。
4.程序填空題
(1)對(duì)數(shù)組按值從大到小的順序排序后輸出,請(qǐng)?zhí)羁铡?/p>
Sinclude<stdio.h>
voidmain()
(
floata[7]={2,6,3,8,3,12,9};
inti;
voidsort(float*,int);
?
for(i=0;i<7;i++)printf(z,%f
printf("\n");
}
voidsort()
(
inti,j,k;floatt;
for(i=0;i<n-l;i++)
(
k=i;
for(j=i+l;j<n;j++)
if()k=j;
{t=*(p+i);*(p+i)=*(p+k);*(p+k)=t;}
sort(a,7)float*p,intn*(p+k)<*(p+j)if(k!=i)
(2)下列函數(shù)在n個(gè)元素的一維數(shù)組中,找出最大值、最小值并傳送到調(diào)用函
數(shù),請(qǐng)?zhí)羁铡?/p>
Sinclude<stdio.h>
voidfind(float*p,intmax,intmin,intn)
i
intk;
*max=*p;
for(k=l;k<n;k++)
(
t=*(p+k);
if()*max=t;
if(t<*min)*min=t;
)
}
floatt;*min=*p;*max<t
B卷
5.寫出下列程序運(yùn)行結(jié)果
(1)
main()
(
inti=l,p;
p=fun(i,i+1);
printf(〃%d\n〃,p);
)
intfun(inta,intb)
(
intf;
if(a>b)
f=l;
elseif(a==b)
f=O;
else
f=-l;
returnf;
-1
⑵鍵盤輸入abcdef<CR>
#include<stdio.h>
voidfun()
charc;
if((c=getchar())!='\n')
fun();
putchar(c);
)
voidmain()
{fun();}
fedcba
(3)
ttinclude<stdio.h>
SdefineC5
intx=l,y=C;
voidmain()
intx;
x=y++;printf(/z%d%d\n/z,x,y);
if(x>4){intx;x=++y;printfC%d%d\n〃,x,y)
x+=y一;
printf(z,%d%d\n〃,x,y);
)
56
77
126
(4)
ttinclude<stdio.h>
intc,a=4;
func(inta,intb)
{c=a*b;a=b-l;b++;return(a+b+1);
voidmain()
!
intb=2,p=0;c=l;
p=func(b,a);
printf%d,%d,%d\nz,,a,b,c,p);
)
4,2,8,9
(5)
unsignedfun6(unsignednum)
unsignedk=l;
do{k*=num%10;num/=10;}
while(num);
returnk;
)
voidmain()
unsignedn=26;
printfC%d\n",fun6(n));
)
12
(6)
ttinclude<stdio.h>
intmax(inta,intb);
mainO
(
intx,y,z,t,m;
scanf(〃%d,%d,%d〃,&x,&y,&z);
t=max(x,y);
m=max(t,z);
printf(〃%d〃,m);
intmax(inta,intb)
if(a>b)
return(a);
else
return(b);
)
運(yùn)行時(shí)若輸入:10,15,9則輸出:
運(yùn)行時(shí)若輸入:300,129,300則輸出:300
(7)
ttinclude<stdio.h>
longsum(inta,intb);
longfactorial(intn);
main()
{
intnl,n2;
longa;
scanf(zz%d,%d〃,&nl,&n2);
a=sum(nl,n2);
printf(/,a=%ld/,,a);
longsum(inta,intb)
longcl,c2;
cl=factorial(a);
c2=factorial(b);
return(cl+c2);
)
longfactorial(intn)
(
longrtn=l;
inti;
for(i=l;i<=n;i++)
rtn*=i;
return(rtn);
}
運(yùn)行時(shí)若輸入:2,3則輸出:—8
運(yùn)行時(shí)若輸入:0,5則輸出:―121
(8)
#include<stdio.h>
ints();
intx,y;
mainO
intn;
x=l;y=2;
n=s();
printf(zzx=%d,y=%d,n=%d〃,x,y,n);
}
ints()
{
intz;
x=3;y=4;
z=x+y;
return(z);
)
程序運(yùn)行后輸出:―3,4,7
(9)以下程序的輸出結(jié)果是a=_,b=_,c=
#include<stdio.h>
intfunc(inta,int*p);
voidmain()
inta=l,b=2,c;
c=func(a,&b);
b=func(c,&a);
a=func(b,&c);
printf(〃a=%d,b=%d,c=%d〃,a,b,c);
)
intfunc(inta,int*p)
(
a++;
*p=a+2;
return(*p+a);
)
361619
第九章預(yù)處理
A部分(本、專科必做)
一、選擇題
以下不正確的敘述是(D)
A、宏替換不占用運(yùn)行時(shí)間。B、宏名無(wú)類型。
C、宏替換只是字符替換。D、宏名必須用大寫字母表示。
C語(yǔ)言的編譯系統(tǒng)對(duì)宏命令的處理(D)
A、在程序運(yùn)行時(shí)進(jìn)行的。B、在程序連接時(shí)進(jìn)行。
C、和C程序中的其它語(yǔ)句同時(shí)進(jìn)行編譯的。
D、在對(duì)源程序中其它語(yǔ)句正式編譯之前進(jìn)行的。
3、以下程序的輸出結(jié)果是(C)。
A、15B、100C、10D、150
^defineMIN(x,y)(x)<(y)?(x):(y)
voidmain()
(
intI,j,k;
i=10;j=15;k=10*MIN(i,j);
printf("96d\n",k);
)
4、以下敘述中正確的是(D)
用#include包含的文件的后綴必須是“.h”。
若一些源程序中包含某個(gè)頭文件;當(dāng)該文件有錯(cuò)時(shí),只需對(duì)該頭文件進(jìn)行修改,
包含此頭文件的所有源程序不必重新進(jìn)行編譯。
宏命令行可以看作是一行C語(yǔ)句。
預(yù)處理是在編譯之前進(jìn)行的。
5、以下敘述中正確的是(C)
A、源程序中所有的行都參加編譯。
B、宏定義常量與const定義常量是一樣的。
C、宏定義可以嵌套定義,即在宏定義中的字符串可以引用另一個(gè)宏定義的標(biāo)識(shí)
符。
D、以上都不正確。
二、填空題
以下程序中for循環(huán)執(zhí)行的次數(shù)是6。
#defineN2
^defineMN+l
SdefineNUM(M+l)*M/2
voidmai
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 學(xué)習(xí)課程故事的心得體會(huì)
- 我的未來(lái)職業(yè)規(guī)劃
- 泛讀教程第三冊(cè)
- 幼兒園防地震安全教育教案
- 2025年中國(guó)液壓自動(dòng)立式磨床市場(chǎng)調(diào)查研究報(bào)告
- 2025年中國(guó)桑綿球市場(chǎng)調(diào)查研究報(bào)告
- 2025年中國(guó)提花披肩市場(chǎng)調(diào)查研究報(bào)告
- 2025年中國(guó)御藤席市場(chǎng)調(diào)查研究報(bào)告
- 2025年中國(guó)小船型毛巾碟市場(chǎng)調(diào)查研究報(bào)告
- 2025年中國(guó)學(xué)生桌塑板市場(chǎng)調(diào)查研究報(bào)告
- GB 7718-2025食品安全國(guó)家標(biāo)準(zhǔn)預(yù)包裝食品標(biāo)簽通則
- 2025年高考?xì)v史總復(fù)習(xí)世界近代史專題復(fù)習(xí)提綱
- 2025-2030中國(guó)蜂蜜行業(yè)營(yíng)銷渠道與多元化經(jīng)營(yíng)效益預(yù)測(cè)研究報(bào)告
- 內(nèi)蒙古匯能集團(tuán)筆試題庫(kù)
- 產(chǎn)后保健知識(shí)課件
- 氧化反應(yīng)工藝安全操作規(guī)程
- 子宮肌瘤病例討論
- 門窗安裝施工方案07785
- 2025年應(yīng)急管理普法知識(shí)競(jìng)賽題(附答案)
- 土壤氡檢測(cè)方案
- 氧化鎵雪崩光電探測(cè)器的研究進(jìn)展
評(píng)論
0/150
提交評(píng)論