C说话试题及谜底
讷讷寡言者一定愚,喋喋利口者一定智。以下是小编为大师搜刮清算C说话试题及谜底,但愿能给大师带来赞助!
C说话试题及谜底 1
一、挑选题((1)-(40)每小题1分,(41)-(50)每小题2分,共60分)
(1) 一个完全的计较机体系包罗
A.主机、键盘与显现器
B.计较机与外部装备
C.硬件体系与软件体系
D.体系软件与利用软件
(2) 十六进制数1000转换成十进制数是
A.4096
B.1024
C.2048
D.8192
(3) 十进制数269转换成十六进制数是
A.10E
B.10D
C.10C
D.10B
(4) 若是用八位二进制补码表现带标记的定点整数,则能表现的十进制数的规模是
A.-127到+127
B.-128到+128
C.-127到+128
D.-128到+127
(5) 以下装备中,既可作为输入装备又可作为输入装备的是
A.鼠标器
B.打印机
C.键盘
D.磁盘驱动器
(6) 以下各论述中,精确的是
A.正数十进制原码的补码是原码本身
B.一切的十进制小数都能精确地转换为无穷位二进制小数
C.汉字的计较机内码便是国标码
D.存储用具备影象才能,此中的信息任什么时辰候都不会丧失
(7) 在以下操纵中,能致使DOS体系从头启动但不停止体系自检的是
A.加电开机
B.按+
C.按++
D.按RESET按钮
(8) 若是给定一个带有通配符的文件名?则在以下各文件中,它能代表的文件名是
A.FA.EXE
B.F.C
C.EF.C
D.FABC.COM
(9) DOS体系启动后,以下文件中常驻内存的是
A.X.COM
B.FORMAT.COM
C.AUTOEXEC.BAT
D.COMMAND.COM
(10) 设A盘的目次布局为(画方框的为目次)
若是以后盘为C盘,A盘的以后目次为\D2,则以下对A盘上文件QR.C的指定中,正当的是
A.\D2\D4\QR.C
B.D4\QR.C
C.A:D4\QR.C
D.A:D2\D4\QR.C(11) 为了要将A盘以后目次(不是根目次)中一切扩大名为.C的文件同名复制到A痰哪柯糪USER中,精确的号令是
A.COPY A:X.C USER\X.C
B.COPY A:X.C A:\USER
C.COPY A:X.C A:USER\
D.COPY A:X.C A:USER\X.C
(12) 为了在屏幕上一次显现以后盘以后目次下的一切扩大名为.TXT的文件内容,以下号令中精确的是
A.TYPE X.TXT
B.TYPE X.TXT CON
C.COPY X.TXT>CON
D.COPY X.TXT CON
(13) 设以后盘为A盘,为了将以后盘以后目次下的文件AB1.TXT毗连在C盘根目次下的文件XYZ.TXT的后面,精确的号令是
A.COPY C:\XYZ.TXT+AB1.TXT
B.COPY AB1.TXT>>C:\XYZ.TXT
C.TYPE AB1.TXT>C:\XYZ.TXT
D.COPY AB1.TXT+C:\XYZ.TXT>C:\XYZ.TXT
(14) 设A盘为启动盘,其目次布局为(画方框的为目次)
此中文件AUTOEXEC.BAT的内容为
MD \XYZ
CD \DOS\USER
则由A盘启动胜利后,A盘的以后目次是
A.\DOS\USER
B.\XYZ
C.\
D.\DOS
(15) 以下DOS号令中为外部号令的是
A.COMP
B.PATH
C.PRINT
D.FORMAT
(16) 设以后盘为C盘,所用的一切软盘已格局化且容量不异,则以下DOS号令中毛病的是
A.DISKCOPY A: C:
B.DISKCOPY A: A:
C.COPY A:X.X
D.COPY A:X.X C:
(17) 以下DOS号令中,有毛病的是
A.TYPE AAB.FOR>PRN
B.TYPE ?AB.FOR
C.COPY X.C PRN
D.COPY CON PRN
(18) 设以后盘为C盘,在以后目次下有全数的DOS体系文件与批处置号令文件AB.BAT,且该批处置号令文件的内容为
FORMAT A:/4
MD \XYZ
CD \XYZ
RD \XYZ
MD \XYZ
若是在1.2软盘驱动器A中拔出一张360K容量的软盘片,履行批自理号令文件AB.BAT后,成果A盘的目次布局是
A.根目次
B.根目次----子目次XYZ----子目次XYZ
C.根目次 ─┬─ 子目次XYZ
└─ 子目次XYZ
D.根目次----子目次XYZ
(19) 以下带有通配符的文件名,能代表文件ABC.FOR的是
A.XBC.?
B.A?.X
C.?BC.X
D.?.?
(20) 设以后盘为C盘,且C盘上含有子目次\DOS,A盘为只要根目次的启动盘(根目次下只要三个DOS体系文件与扩大名为. C的文件)。以下号令组中的两个号令从成果上能够以为等价的是
A.DEL \DOS与RD \DOS
B.FORMAT A:与DEL A:X.X
C.FORMAT A: /S与DEL A:X.?
D.COPY A:F1 F2与REN A:F1 F2
(21) 设a、b和c都是int型变量,且a=3,b=4,c=5,则上面的抒发式中,值为0的抒发式是
A.’a’&&’b’
B.a<=b
C.a||b+c&&b-c
D.!((a (22) 请读法式片断:
int i=65536; printf("%d\n",i);
上面法式片断的输入成果是
A.65536
B.0
C.有语法毛病,无输入成果
D.-1
(23) 设ch是char型变量,其值为A,且有上面的抒发式:
ch=(ch>=’A’&&ch<=’Z’)?(ch+32):ch
上面抒发式的值是
A.A
B.a
C.Z
D.z
(24) 若x和y都是int型变量,x=100,y=200,且有上面的法式片断:
printf("%d",(x,y));
上面法式片断的输入成果是
A.200
B.100
C.100 200
D.输入格局符不够,输入不肯定的值
(25) 上面各语句行中,能精确停止赋字符串操纵的语句行是
A.char st[4][5]={"ABCDE"};
B.char s[5]={’A’,’B’,’C’,’D’,’E’};
C.char Xs; s="ABCDE";
D.char Xs; scanf("%s",s);
(26) 若k是int型变量,且有上面的法式片断:
k=-3
if(k<=0) printf("####")
else printf("&&&&");
上面法式片断的输入成果是
A.####
B.&&&&
C.####&&&&
D.有语法毛病,无输入成果
(27) 若x是int型变量,且有上面的法式片断:
for(x=3; x<6; x++) printf((x%2)?("XX%d"):("##%d\n"),x);
上面法式片断的输入成果是
A.XX3
B.##3
C.##3
D.XX3##4
##4 XX4 XX4##5 XX5
XX5 ##5
(28) 请读法式:
#include
f(char Xs)
{ char Xp=s;
while( Xp!=’\0’) p++;
return(p-s);
}
main()
{ printf("%d\n",f("ABCDEF"));}
上面法式的输入成果是
A.3
B.6
C.8
D.0
(29) 请读法式:
#include
main()
{ int a; float b, c;
scanf("-?O",&a,&b,&
C.;
printf("\na=%d, b=%f, c=%f\n", a, b,
C.;
}
若运转时从键盘上输入9876543210(表现回车),则上面法式的输入成果是
A.a=98, b=765, c=4321
B.a=10, b=432, c=8765
C.a=98, b=765.000000, c=4321.000000
D.a=98, b=765.0, c=4321.0
(30) 请读法式:
#include
main()
{ int n[2], i, j, k;
for(i=0;i<2;i++) n[i]=0;
k=2
for(i=0;i for(j=0;j printf("%d\n",n[k]);
}
上面法式的输入成果是
A.不肯定的值
B.3
C.2
D.1
(31) 请读法式片断:
char str[]="ABCD", Xp=str;
printf("%d\n",X(p+4));
上面法式的输入成果是
A.68
B.0
C.字符"D"的地点
D.不肯定的值
(32) 请读法式片断:
#include
main()
{ int a, b;
for(a=1;b=1;a<=100;a++)
{ if(b>=20) break;
if(b%3==1)
{b+=3;
continue;
}
b-=5;
}
printf("%d\n",a);
}
上面法式的输入成果是
A.7
B.8
C.9
D.10
(33) 若要用上面的法式片断使指针变量p指向一个存储整型变量的静态存储单位:
int Xp;
p=__________ malloc( sizeof(int));
则应填入
A.int
B.inst X
C.(Xint)
D.(int X)
(34) 请读法式片断(字符串内不空格):
printf("%d\n",strlen("ATS\n012\1\\"));
上面法式片断的输入成果是
A.11
B.10
C.9
D.8
(35) 请读法式:
#include
#include
main()
{ charXs1="AbCdEf", Xs2="aB";
s1++; s2++;
printf("%d\n",strcmp(s1,s2));
}
上面法式的输入成果是
A.正数
B.正数
C.零
D.不肯定的值
(36) 请读法式:
#include
func( int a, int
B.
{ int c;
c=a+b;
return c;
}
main()
{ int x=6, y=7, z=8, r;
r=func( x--,y==,x+y),z--);
printf("%d\n",r);
}
上面法式的输入成果是
A.11
B.20
C.21
D.31
(37) 请读法式:
#include
int a[]={2,4,6,8};
main()
{ int i;
int Xp=a;
for(i=0;i<4;i++) a[i]=Xp++;
printf("%d\n",a[2]);
}
上面法式的输入成果是
A.6
B.8
C.4
D.2
(38) 请读法式:
#include
char fun(char X
C.
{ if( Xc<=’z’ c="">=’A’) Xc-=’A’-’a’;
return Xc;
}
main()
{ char s[81], Xp=s;
gets(s);
while(Xp)
{Xp=fun(p); putXp); p++;}
put’\n’);
}
若运转时从键盘上输入OPEN THE DOOR(表现回车),则上面法式的输入成果是
A.oPEN tHE door
B.open the door
C.OPEN THE DOOR
D.Open The Door
(39) 请读法式:
#include
void fun( int Xs)
{ static int j=0;
do
s[j]+=s[j+1];
while(++j<2);
}
main()
{ int k, a[10]={1,2,3,4,5};
for(k=1; k<3; k++) fun(a);
for(k=0; k<5; k++) printf("%d", a[k]);
}
上面法式的输入成果是
A.34756
B.23445
C.35743
D.12345
(40) 请读法式:
#include
#define SUB(X,Y) (X)XY
main()
{ int a=3, b=4;
printf("%d", SUB(a++, b++));
}
上面法式的输入成果是
A.12
B.15
C.16
D.20(41) 请读法式:
#include
main()
{ int mun=0;
while(num<=2)
{ num++; printf("%d\n",num);}
}
上面法式的输入成果是
A.1
B.1
C.1
D.1
2 2 2
3 3
4
(42) 请读法式:
#include
main()
{ float x,y;
scan("%f",&x);
if(x<0.0) y=0.0
else if((x<5.0)&&(x!=2.0))
y=1.0/(x+2.0);
else if (x<10.0) y=1.0/x;
else y=10.0;
printf("%f\n",y);
}
若运转时从键盘上输入2.0(表现回车),则上面法式的输入成果是
A.0.000000
B.0.250000
C.0.500000
D.1.000000
(43) 请读法式:
#include
main()
{ 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++; b++; break;
}
printf("a=%d, b=%d\n",a,
B.;
}
上面法式的输入成果是
A.a=2, b=1
B.a=1, b=1
C.a=1, b=0
D.a=2, b=2
(44) 如有上面的法式片断:
int a[12]={0}, Xp[3], XXpp, i;
for(i=0; i<3; i++)
p[i]=&a[iX4];
pp=p;
则对数组元素的毛病援用是
A.pp[0][1]
B.a[10]
C.p[3][1]
D.X(X(p+2)+2)
(45) 请读法式:
#include
#include
main()
{ float x,y,z;
scan("%f%f",&x,&y);
z=x/y;
while(1)
{ if(fabs(z)>1.0)
{ x=y; y=z; z=x/y;
}
else break
}
printf("%f\n",y);
}
若运转时从键盘上输入3.6 2.4(表现回车),则输入的成果是
A.1.500000
B.1.600000
C.2.000000
D.2.400000
(46) 请读法式:
#include
f(in b[], int n)
{ int i, r;
r=1;
for(i=0; i<=n; i++) r=rXb[i];
return r;
}
main()
{ int x, a[]={ 2,3,4,5,6,7,8,9};
x=f(a, 3);
printf("%d\n",x);
}
上面法式的输入成果是
A.720
B.120
C.24
D.6
(47) 请读法式:
#include
#include
void fun( char Xs)
{ char a[10];
strcpy( a, "STRING");
s=a;
}
main()
{ char Xp;
fun(p);
x=f(a, 3);
printf("%s\n",p);
}
上面法式的输入成果是(└┘表现空格)
A.STRING└┘└┘└┘└┘
B.STRING
C.STRING└┘└┘└┘
D.不肯定的值
(48) 若已成立上面的链表布局,指针p、s别离指向图中所示的结点,则不能将s所指的结点拔出到链表开端的语句组是
A.s->next=NULL; p=p->next; p->next=s;
B.p=p->next; s->next=p->next; p->next=s;
C.p=p->next; s->next=p; p->next=s;
D.p=(Xp).next; (Xs).next=(Xp).next; (Xp).next=s;
(49) 请读法式:
#include
void fun(float Xpl, float Xp2, float Xs)
{ s=( float X )calloc( 1, sizeof(float));
Xs=Xp1+ X(p2++);
}
main()
{ float a[2]={1.1, 2.2}, b[2]={10.0, 20.0}, Xs=a;
fun(a, b, s)
printf("%f\n",Xs);
}
上面法式的输入成果是
A.11.100000
B.12.100000
C.21.100000
D.1.100000
(50) 请读法式:
#include
#include
void fun( char Xw, int m)
{ char s, Xp1, Xp2;
p1=w; p2=w+m-1;
while (p1 { s=Xp1++; Xp1=Xp2--; Xp2=s;}
}
main()
{ char a[]="ABCDEFG";
fun( a, strlen(a));
puts(a);
}
上面法式的输入成果是
A.GFEDCBA
B.AGADAGA
C.AGAAGAG
D.GAGGAGA
二、填空题(每空2分,共40分)
请将每空的精确谜底写在答题卡上【1】-【20】序号后的横线上,答在试卷上不得分。
(1) DOS号令分为外部号令与外部号令,XCOPY号令是 【1】 号令
(2) 为了列出以后盘以后目次中一切第三个字符为C的文件名的`有关信息,应当用号令 【2】 。
(3) 设以后盘为A盘,以后目次为\X\Y,A盘上的一个文件QR.C在以后目次下的子目次W中。现已将A盘的以后目次改成\D\XY,以后盘改成C盘,如需指定A盘上该文件应写成 【3】 。
(4) 用十六进制给存储器中的字节地点停止编号,其地点编号是从0000到FFFF,则该存储器的容量是【4】KB。
(5) 设有两个八位二进制数00010101与01000111相加,其成果的十进制表现为 【5】 。
(6) 数学款式 写成C说话抒发式是 【6】 。
(7) 上面法式的输入成果是 【7】 。
#include
main()
{ static char b[]="Goodbye";
char Xchp=&b[7];
while( --chp >=&b[0]) put Xchp);
put’\n’);
}
(8) 上面法式的输入成果是 【8】 。
#include
void as( int x, int y, int Xcp, int Xdp)
{ Xcp=x+y;
Xdp=x-y;
}
main()
{ int a=4, b=3, c, d;
as( a, b, &c, &d);
printf( ’%d %d\n", c, d);
}
(9) 请读法式:
#include
main( int argc, char Xargv[])
{ int i;
printf( ’%d\n", argc);
for( i=0; i<=argc+1; i++) printf( "%s ", argv[i]);
printf("\n");
}
若上面的法式编译、毗连后天生可履行文件ABC.EXE,则输入以下号令行
abc file1 file2(表现回车)
法式履行后的输入成果是 【9】 。
(10) 前提“20 (11) 设二进制数a是00101101,若想经由进程异或运算a^b使a的高4位取反,低4位稳定,则二进制数b应是 【11】 。
(12) 如有以下申明和界说语句,则变量w在内存中所占的字节数是 【12】 。
union aa
{ float x, y;
char c[6];
};
struct st { union aa v; float w[5]; double ave; } w;
(13) 上面法式的输入成果是 【13】 。
#include
#define N 5
fun( char Xs, char a, int n)
{ int j;
Xs=a; j=n;
while( e return j;
}
main()
{ char s[N+1];
int k, p;
for( k=1; k<=N; k++)
s[k]=’A’+k+1;
printf( "%d\n", fun(s, ’E’, N));
}(14) 上面法式的输入成果是 【14】 。
#include
void fun( char Xa1, char Xa2, int n)
{ int k;
for( k=0; k a2[k]=( a1[k]-’A’-3+26)&+’A’;
a2[n]=’\0’;
}
main()
{ char s1[5]="ABCD", s2[5];
fun( s1, s2, 4);
puts( s2);
}
(15) 上面的findmax函数前往数组s中最大元素的下标,数组中元素的个数由t传入,请填空。
findmax( int s[], int t)
{ int k, p;
for( p=0, k=p; p if( s[p]>s[k]) 【15】 。
return k;
}
(16) 上面法式的输入成果是 【16】 。
#include
fun( int x)
{ int p;
if( x==0||x==1) return(3);
p=x-fun( x-2);
return p;
}
main()
{ printf( "%d\n", fun(9));}
(17) 上面法式的输入成果是 【17】 。
#include
funa( int a, int b)
{ return a+b;}
funb( int a, int b)
{ return a-b;}
sub( int (Xt)(), int x, int y)
{ return((Xt)( x,y));}
main()
{ int x, (Xp)();
p=funa;
x=sub(p,9,3);
x+=sub(funb, 8, 3);
printf("%d\n", x);
}
(18) 上面法式的输入成果是 【18】 。
#include
main()
{ char Xp[]={ "BOOL", "OPK", "H", "SP"};
int i;
for(i=3; i>=0; i--,i--) printf( "%c", Xp[i]);
printf("\n");
}
(19) 为了成立如图所示的存储布局(即每一个结点含两个域,data是数据域,next是向结点的指针域),请填空。
data next
struct link { char data; 【19】 } node;
(20) 上面的法式用来统计文件中字符的个数,请填空。
#include
main()
{ FILE Xfp;
long num=0;
if(( fp=fopen("fname.dat","r"))==NULL)
{ printf( "Can’t open file! \n"); exit(0);}
while 【20】
{ fgetc(fp); num++;}
printf("num=%d\n", num);
fclose(fp);
}
C说话试题及谜底 2
一`挑选题((1)~(40)题每题1分,(41)~(50)题每题2分,共60分)
(1)C (2)A (3)B (4)D (5)D (6)A (7)C (8)B (9)D (10)C
(11)B (12)D (13)A (14)C (15)B (16)A (17)B (18)A (19)C (20)C
(21)D (22)B (23)B (24)A (25)C (26)D (27)D (28)B (29)C (30)A
(31)B (32)B (33)D (34)C (35)A (36)C (37)A (38)B (39)C (40)A
(41)C (42)C (43)A (44)C (45)B (46)B (47)D (48)C (49)D (50)C
二` 填空题(每空2分,共40分)
(第(2)`(3)空许可小写或巨细写夹杂利用,别的空均须与谜底一样)
(1) 外部
(2) DIR ?? CX.X
(3) A:\X\Y\W\QR.C
(4) 64
(5) 92
(6) pow(sin(x),2) X (a+b)/(a-b) 或 sit(x) X sit(x) X (a+b)/(a-b)
(7) eybdooG
(8) 7 1
(9) 3 abc.exe file1 file2 (注:两个谜底,每一个1分)
(10) ((20 (11) 11110000
(12) 34
(13) 3
(14) XYZA
(15) k=p
(16) 7
(17) 17
(18) SO
(19) struct link Xnext
(20) (!feof(fp))或(feof(fp)==0)
C说话试题及谜底 3
1: 第1题请编写函数fun,其功效使:将两个两位正整数a b归并构成一个整数放在c中。归并的体例使:将a数的十位和个位数顺次放在c数的百位和个位上,b数的十位和个位数顺次放在c数的千位和十位上。
谜底:
void fun(int a,int b,long Xc)
{Xc=(b/10)X1000+(a/10)X100+(b%10)X10+a%10;}
2: 第2题请编写一个函数fun,它的功效使:计较n门课程的均匀分,计较成果作为函数值前往。
谜底:
float fun(float Xa,int n)
{float ave=0.0;
int i;
for(i=0;i
ave+=a;
ave/=n;
return ave;}
3: 第3题假定输入的字符串中只包罗字母和X号。请编写函数fun,它的功效使:将字符串尾部的X号全数删除,后面和中心的X号不删除。
谜底:
void fun(char Xa)
{int i=0;
char Xp,Xq;
p=q=a;
while(Xp)
p++;
p--;
while(Xp==‘X’)
p--;
while(q<=p)
{a=Xq;
i++;
q++;}
a=‘’;}
4: 第4题请编写函数fun,其功效是:将两个两位数的正整数a b归并构成一个整数放在c中,归并的体例是:将a数的.十位和个位数顺次放在c的个位和百位上,b数的十位和个位数顺次放在c数的千位和十位上。
谜底:
void fun(int a,int b,long Xc)
{c=(b/10)X1000+(a%10)X100+(b%10)X10+a/10;}
5: 第5题 n论理学生的成就已在主函数中放入一个带头节点的链表布局中,h指向链表的头节点。请编写函数fun,它的功效是:求出均匀分,由函数值前往。
谜底:
double fun(strec Xh)
{double aver=0.0;
while(h!=null)
{aver+=h->s;
hy=h->next;}
aver/=n;
return aver;}
6: 第6题请编写函数fun,计较并输入给定10个数的方差。
谜底:
double fun(double x[10])
{int i,j;
double s=0.0,s1=0.0;
for(i=0;i<10;i++)
s1+=x;
s1/=10;
for(j=0;j<10;j++)
s+=(x[j]-s1)X(x[j]-s1);
s/=10;
s=pow(s,0.5);
return s;}
7: 第7题请编写函数fun,其功效是:将两个两位数的正整数a b归并构成一个整数放在c 中。归并的体例是:将a数的十位和个位数顺次放在c数的千位和十位上,b数的十位和个位数顺次放在c数的个位和百位上。
谜底:
void fun(int a,int b,long Xc)
{Xc=(a/10)X1000+(a%10)X10+(b%10)X100+b/10;}
C说话试题及谜底 4
c说话试题
一 挑选题(7分,每小题0.5分)
1.C说话源法式的根基单位是( )。
A 进程 B 函数 C 子法式 D 标识符
2.以下法式的输入成果是( )。
main( )
{ int a=7,b=5;
printf("%d",b=b/a);
}
A 5 B 1 C 0 D不肯定值
3.假定变量a,b均为整型,抒发式(a=5,b=2,a>b?a++:b++,a+b)的值是( )。
A 7 B 8 C 9 D 2
4.设a为int型变量,履行以下赋值语句后,a的取值别离是( )。
a=125.534; a=(int)125.521%4; a=5<<2;
A 125,31,1 B 125,1,20 C 125,31,20 D 125.534,2,20
5.设有以下法式段,上面描写中精确的是 ( )。
int k=10; while(k=0) k=k-1;
A 轮回履行一次 B轮回是无穷轮回 C轮回体语句一次也不履行 D轮回体语句履行一次
6.以下法式的输入成果为( )。
int i;
void prt( )
{ for(i=5;i<8;i++) printf("%c",X);
printf(" ");
}
main( )
{ for(i=5;i<=8;i++) prt( );
}
A XXX B XXX XXX XXX XXX C XXX XXX D X X X
7.在C说话法式中,以下说法精确的是( )。
A函数的界说能够嵌套,但函数的挪用不能够嵌套
B函数的界说不能够嵌套,但函数的挪用能够嵌套
C函数的界说和函数的挪用都不能够嵌套
D函数的界说和函数的挪用都能够嵌套
8.以下函数挪用语句中含有( )个实参。
func((e1,e2),(e3,e4,e5));
A 2 B 3 C 5 D 语法毛病
9.以下法式的输入成果为( )。
#define ADD(x) xXx
main( )
{ int a=4,b=6,c=7,d=ADD(a+b)Xc;
printf("d=%d",d);
}
A d=70 B d=80 C d=140 D d=700
10.已知职工记实描写以下,在Turbo C中,体系为变量w分派( )字节的空间。
struct worker
{ int no;
char name[20];
char sex;
union
{ int day; int month; int year;}birth;
} w;
A 29 B 20 C 25 D 6
11.设有以下界说,值为5的列举常量是( )。
enum week{sun,mon=4,tue,wed,thu,fri,sat} w;
A tue B sat C fri D thu
12.上面选项中精确的赋值语句是(设 char a[5],Xp=a;)( )。
A p="abcd"; B a="abcd"; C Xp="abcd"; D Xa="abcd";
13.设有以下法式段,则值为6的抒发式是( )。
struct st { int n; struct st Xnext;};
static struct st a[3]={5,&a[1],7,&a[2],9,0 },Xp;
p=&a[0];
A p++->n B ++p->n C p->n++ D (Xp).n++
14.C说话中的文件范例只要( )。
A 索引文件和文本文件两种 B 文本文件一种
C 二进制文件一种 D ASCII码文件和二进制文件两种
二 判定对错,对的划“√”,错的划“×”(5分,每小题0.5分)
1.在Turbo C中,整型数据在内存中占2个字节。( )
2.int i=20;switch(i/10){case 2:printf("A");case 1:printf("B");}的输入成果为A。( )
3.break语句用在轮回体中,可竣事本层轮回,continue语句用在轮回体中,可竣事本次轮回。( )
4.函数的递归挪用不过是一个函数直接或直接地挪用它本身。( )
5.函数strlen("ASDFG")的值是7。( )
6.经由进程return语句,函数能够带回一个或一个以上的前往值。( )
7.布局体范例只要一种。 ( )
8.char Xp="girl";的寄义是界说字符型指针变量p,p的值是字符串"girl"。( )
9.如有界说:char Xp(char a[10]);则p是函数名。( )
10.用fopen("file","r+");翻开的文件"file"能够停止点窜。 ( )
三 写出以下法式的运转成果(10分,每小题2分)
1.float average (float array[10])
{ int i;
float aver,sum=array[0];
for (i=1;i<10;i++)
sum=sum+array[i];
aver=sum/10;
return(aver);
}
main( )
{ float score[10]={89,67.5,78,91,56,82.5,65,70,79,88},aver;
int i;
aver=average (score);
printf (“average score is %5.2f”,aver);
}
2.main( )
{ char a[5]={‘A’,‘B’,‘C’,‘D’,‘E’},Xp=a,XXpa;
printf(“%2c”,Xp);
printf(“”);
printf(“%2c”,XX(pa=&p));
}
3.main( )
{ int a,b,s=0;
for(a=1,b=1;a<=100;a++)
{ if(b>=20) break;
if(b%3==1)
{ b+=3; continue; }
b-=5;
}
printf(“a=%d b=%d”,a,b);
}
4.main()
{ printf(“main( ) :%d”,fact(5));
fact(-5);
}
fact(int value)
{ int f;
if(value<0)
{ printf(“Arg error");
return(-1);
}
else if(value==1||value==0) f=1;
else f=valueXfact(value-1)+1;
printf(“This called value=%d”,f);
return f;
}
5.main( )
{ int a=012,b=0x12,k=12;
char c=‘102’,d=‘’;
printf(“a=%d b=%d k=%d”,a,b,k);
printf(“c=%c,d=%c%o”,c,d,a);
a=‘A’; c=49;
printf(“a=%d c=%c”,a,c);
}
四 浏览以下法式,在 处填入恰当内容,使法式完全(8分,每一个空1分)
1.有一个3X4矩阵,求此中的最大元素。
max_value( (1) )
{ int i,j,max;
max=array[0][0];
for(i=0;i<3;i++)
for(j=0;j<4;j++)
if(array[i][j]>max)
max=array[i][j];
(2) ;
}
main( )
{ int a[3][4], i,j;
for(i=0;i<3;i++)
for(j=0;j<4;j++)
(3) ;
printf(“max value is %d”,max_value(a));
}
2.输入x、y两个整数,按先大后小的挨次输入x、y。
#include “stdio.h”
main( )
{ int x,y, Xpx,Xpy, (4) ;
scanf(“%d%d”,&x,&y);
(5) ; (6) ;
if(x
{ p=px; px=py; py=p; }
printf(“x=%d,y=%d”,x,y);
printf(“MAX=%d,MIN=%d”,Xpx,Xpy);
}
3.用挑选排序法对肆意10个整数根据由小到大排序。
main()
{ int a[11],i,j,k,t;
printf("Please input 10 numbers:");
for(i=1;i<11;i++) scanf("%d",&a[i]);
printf("");
for(i=1;i<=9;i++)
{ (7) ;
for(j=i+1; (8) ;j++)
if(a[j]>a[k]) k=j;
if(k!=i)
{ t=a[k]; a[k]=a[i]; a[i]=t;}
}
printf("The sorted numbers:");
for(i=1;i<11;i++) printf("%d ",a[i]);
}
谜底
一 挑选题(7分,每小题0.5分)
1. B 2. C 3. B 4. B 5. C
6. A 7. B 8. A 9. A 10. C
11. A 12. A 13. B 14. D
二 判定对错,对的划“√”,错的划“×”(5分,每小题0.5分)
1.× 2.× 3.√ 4.√ 5.×
6.× 7.× 8.× 9.√ 10.√
三 写出以下法式的运转成果(10分,每小题2分)
1. 2. 3.
4. 5.
四 浏览以下法式,在 处填入恰当内容,使法式完全(8分,每一个空1分)
1.(1)int array[3][4](int array[][4]) (2)return(max) (3)scanf(“%d”,&a[i][j])
2.(4)Xp (5)px=&x(py=&y) (6)py=&y(px=&x)
3.(7) (8)
2003C说话试题3
一 挑选题(24分,每小题2分)
1.已知函数fread的挪用情势为fread(buffer,size,count,fp),此中buffer代表的是( )。
A 寄存读入数据项的存储区 B 寄存读入数据的地点或指向此地点的指针
C 一个指向所读文件的文件指针 D 一个整形变量,代表要读入的数据项总数
2.以下法式的输入成果为( )。
main( )
{ int i=010,j=10;
printf("%d,%d",i++,j--);
}
A 11,9 B 9,10 C 8,10 D 9,9
3.设a为int型变量,履行以下赋值语句后,a的取值别离是( )。a=125.534;a=20.0/3;a=(int)125.521%4;a=5<<2;
A 125,6,31,1 B 125,6,1,20 C 125,6.666666,31,20 D 125.534,6.666666,2,20
4.设i和k都是int范例,则for轮回语句( )。
for(i=0,k=-1;k=1;i++,k++) printf("XXXX");
A 轮回竣事的前提不正当 B 轮回体一次也不履行 C 轮回体只履行一次 D 是无穷轮回
5.以下法式的输入成果为( )。
main( )
{ char c;
int i;
for(i=65;i<68;i++)
{ c=i+32;
switch(c)
{ case a:case b:case c:printf("%c,",c);break; default:printf("end");}
}
}
A a,b,c,end B a,a,a,end C a,a,a, D a,b,c,
6.函数挪用语句:fseek(fp,-10L,2);的寄义是( )。
A 将文件地位指针从文件开端处向文件头的标的目的挪动10个字节
B 将文件地位指针从以后地位向文件头的标的目的挪动10个字节
C 将文件地位指针从以后地位向文件开端标的目的挪动10个字节
D 将文件地位指针移到间隔文件头10个字节处
7.以下法式的输入成果为( )。
main( )
{ char s1[40]="country",s2[20]="side";
int i=0,j=0;
while(s1[i]!=) i++;
while(s2[j]!=) s1[i++]=s2[j++];
s1[i]=0;
printf("%s",s1);
}
A side B country C sidetry D countryside
8.以下说法不精确的是( )。
A 主函数main中界说的变量在全部文件或法式中有效
B 差别函数中,能够利用不异名字的变量
C 情势参数是部分变量
D 在一个函数外部,能够在复合语句中界说变量,这些变量只在本复合语句中有效
9.在以下法式段中,列举变量 c1的值是( )。
enum color { red,yellow,blue=4,green,white}c1; c1=yellow; c1=white;
A 1 B 3 C 5 D 6
10.设有申明 int (Xptr)();此中标识符ptr是( )。
A 是一个指向整形变量的指针 B 是一个指针,它指向一个函数值是int的`函数
C 是一个函数名 D界说不正当
11.界说由n个指向整形数据的指针构成的数组p,其精确的体例为( )。
A int p; B int (Xp)[n]; C int Xp[n]; D int (Xp)( );
12.具备不异范例的指针范例变量p与数组a,不能停止的操纵是( )。
A p=a; B Xp=a[0]; C p=&a[0]; D p=&a;
二 判定对错,对的划“√”,错的划“×”(20分,每小题2分)
1.参与位运算的数据能够是任何范例的数据。( )
2.如有界说和语句:int a;char c;float f;scanf("%d,%c,%f",&a,&c,&f);若经由进程键盘输入:10,A,12.5,则a=10,c=‘A’,f=12.5。( )
3.C说话把文件看做是一个字符(字节)的序列。( )
4.如有宏界说:#define S(a,b) t=a;a=b;b=t因为变量t没界说,以是此宏界说是毛病的。( )
5.在Turbo C中,上面的界说和语句是正当的:file Xfp;fp=fopen("a.txt","r");( )
6.如有界说:char s[ ]="china";则Turbo C体系为数组s斥地6个字节的内存单位。( )
7.如有界说和语句:int a[3][3]={{3,5},{8,9},{12,35}},i,sum=0;for(i=0;i<3;i++) sum+=a[i][2-i];则sum=21。( )
8.如有界说和语句:struct student { int num; char name[10]; float score;} s[5]={{1,"lili",98.5},{9,"xiaohua",66}},Xp=s;printf("%d",Xp++);输入成果是1。( )
9.在法式中界说了一个布局体范例后,能够屡次用它来界说具备该范例的变量。( )
10.在Turbo C中,此界说和语句是正当的:enum aa{ a=5,b,c}bb;bb=(enum aa)5;( )
三 写出以下法式的运转成果(36分,每小题6分)
1.main( )
{ int i=29,j=6,k=2,s;
s=i+i/j%k-9;
printf(“s=%d”,s);
}
2.main( )
{ int x=31,y=2,s=0;
do
{ s-=xXy;
x+=2;
y-=3;} while( x%3==0);
printf(“x=%d y=%d s=%d”,x,y,s);
}
3.main( )
{ int a[6]={10,20,30,40,50,60},i;
invert(a,0,5);
for(i=0;i<6;i++) printf(“%d,”,a[i]);
printf(“”);
}
invert(int s[ ],int i,int j)
{ int t;
if(i
{ invert(s,i+1j-1);
t=s[i];s[i]=s[j];s[j]=t;
}
}
4.#include
main()
{ char str[ ]=“The C program”,c;
int i;
for(i=2;(c=str[i])!=‘’;i++)
{ switch(c)
{ case ‘g’: ++i; break;
case ‘o’: continue;
default: printf(“%c”,c); continue;
}
printf(“X”);
}
printf(“”);
}
5.struct w
{ char low;
char high;
};
union u
{ struct w byte;
short word;
}uw;
main( )
{ int result;
uw.word=0x1234;
printf(“word value:%04x”,uw.word);
printf(“high byte:%02x”,uw.byte.high);
printf(“low byte:%02x”,uw.byte.low);
uw.byte.low=0x74;
printf(“word value:%04x”,uw.word);
result=uw.word+0x2a34;
printf(“the result:%04x”,result);
}
6.main()
{ char Xs2=“I love China!”,XXs1=&s2;
char Xs3,c,Xs4=“w”;
s3=&c;
Xs3=‘H’;
s2=s2+2;
printf(“%s %c %s %c”,s2,Xs3,s4,XXs1);
}
四 浏览以下法式,在 处填入恰当内容,使法式完全(20分,每一个空2分)
1. 百马百担标题问题:有100匹马,驮100担货,大马驮3担,中马驮2担,两匹小马驮1担,问大、中、小马各几多匹?
main( )
{ int hb,hm,hl,n=0;
for(hb=0;hb<=100;hb+= (1) )
for(hm=0;hm<=100-hb;hm+= (2) )
{ hl=100-hb- (3) ;
if(hb/3+hm/2+2X (3) ==100)
{ n++;
printf("hb=%d,hm=%d,hl=%d",hb/3,hm/2,2Xhl);
}
}
printf("n=%d",n);
}
2.用“起泡法”对输入的10个字符排序后按从小到大的顺序输入。
#define N 10
char str[N];
main()
{ int i,flag;
for(flag=1;flag==1;)
{ scanf("%s",str);
flag=0;
printf("");
}
sort(___(4)___);
for(i=0;i
printf("%c",str[i]);
printf("");
}
sort(char str[N])
{ int i,j;
char t;
for(j=1;j
for(i=0;(i
if(str[i]>str[i+1])
{ t=str[i];
____(5)____;
____(6)____;
}
}
3.以下法式是一个函数,功效是求二阶矩阵(m行n列矩阵)的一切靠外侧的各元素值之和。(本法式中二阶矩阵用一维数组来表现。)
比方,矩阵为:
3 0 0 3
2 5 7 3
1 0 4 2
则一切靠外侧的各元素值之和为3+0+0+3+2+3+1+0+4+2=18。
add(int m,int n,int arr[])
{ int i,j,sum=0;
for(i=0;i
for(j=0;j
sum=sum+ (7) ;
for(j=0;j
for(i=1; (8) ;i++)
sum=sum+arr[iXn+j];
return(sum);
}
4.用指针作函数参数,编法式求一维数组中的最大和最小的元素值。
#define N 10
main()
{ void maxmin(int arr[],int Xpt1,int Xpt2,int n);
int array[N]={10,7,19,29,4,0,7,35,-16,21},Xp1,Xp2,a,b;
p1=&a; p2=&b;
maxmin(array,p1,p2,N);
printf("max=%d,min=%d",a,b);
}
void maxmin(int arr[],int Xpt1,int Xpt2,int n)
{ int i;
Xpt1=Xpt2=arr[0];
for(i=1;i
{ if(arr[i]>Xpt1) (9) ;
if(arr[i]
}
}
谜底
一、挑选题(24分,每小题2分)
1.( B ) 2.( C ) 3.( B ) 4.( D ) 5.( D ) 6.( A )
7.( D ) 8.( A ) 9.( D ) 10.( B ) 11.( C ) 12.( D )
二、判定对错,对的划“√”,错的划“×”(20分,每小题2分)
1.( × ) 2.( √ ) 3.( √ ) 4.( × ) 5.( × )
6.( √ ) 7.( √ ) 8.( × ) 9.( √ ) 10.( √ )
三、写出以下法式的运转成果(36分,每小题6分)
1. s=20 2.x=35 y=-4 s=-29 3.60,50,40,30,20,10,
4.e C prXam 5.word value:1234 6.love China! H w l
high byte:12
low byte:34
word value:1274
the result:3ca8
四、浏览以下法式,在 处填入恰当内容,使法式完全(20分,每一个空2分)
1.(1) 3 (2) 2 (3)hm hl
2.(4) str (5) str[i]=str[i+1] (6) str[i+1]=t
3.(7) arr[iXn+j](或arr[iX10+j])
(8) i
4.(9) Xptr1=arr[i] (10) Xptr2=arr[i]
C说话试题及谜底 5
1. 以下法式履行后sum 的值是
main()
{ int i , sum;
for(i=1;i<6;i++) sum+=i;
printf("%d ",sum);
}
A)15
B)14
C) 不肯定
D)0
谜底:C
2. 当挪用函数时,实参是一个数组名,则向函数传递的是
A) 数组的'长度
B) 数组的首地点
C) 数组每一个元素的地点
D) 数组每一个元素中的值
谜底:B
3. 以下法式的输入成果是
main()
{ int i, x[3][3]={1,2,3,4,5,6,7,8,9};
for(i=0;i<3;i++) printf("%d,",x[i][2-i]);
}
A) 1,5,9
B) 1,4,7
C) 3,5,7
D)3,6,9
谜底:C
C说话试题及谜底 6
标题问题:
请编写一个函数fun,它的.功效是:将ss所指字符串中一切下标为奇数地位上的字母转换为大写(若该地位上不是字母,则不转换)。
谜底:
void fun(char Xss)
{
int I,n;
n=strlen(ss);
for(i=1;i
if(ss[i]>=‘a’&& ss[i]<=‘z’)
ss[i]=ss[i]-32;
}
标题问题:
请编写一个函数fun,它的功效是:求除一个2×m整型二维数组中最大元素的值,并将此值前往挪用函数。
谜底:
int fun(int a[][M])
{
int I,j,max;
max=a[0][0];
for(i=0;i<2;i++)
for(j=0;j
if(a[i][j]>max)
max=a[i][j];
return max;
}
【C说话试题及谜底】相干文章:
C说话摹拟试题及谜底03-28
C说话考前操练试题及谜底03-28
C说话测验试题及谜底06-12
C说话测试题及谜底07-03
C说话测尝尝题及谜底08-02
C说话笔尝尝题及谜底12-05
经常利用C说话测试题及谜底12-05
C说话试题03-28
C说话试题(精选)12-05