上海龙凤419

C说话

C说话试题及谜底

时辰:2024-07-26 19:04:54 C说话 我要投稿

C说话试题及谜底

  讷讷寡言者一定愚,喋喋利口者一定智。以下是小编为大师搜刮清算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;

  for(p=0;p

  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