1、一、选择题 1. 如下论述不正确的是( )。 A)C语言的执行总是从 main函数开始 B)一个C源程序必须包括一个main函数 C)C语言程序的基本组成单位是函数 D)在编译C程序源程序时,可发觉注释中的拼写错误 2.如下( )是错误的整型常量。 A)-0xcdf B)018 C)0xe D)011 3.若有定义:int a,b;double x,则如下不符合C语言语法的体现式是( )。 A)x%(-3) B)a+=-2 C)a=b=2 D)x=a+b 4.若有定义:int i,j;则体现式(i=2,j=5,i++,i+j++)的值是( )。
2、A)7 B)8 C)9 D)10 5.已经有如下定义和输入语句 int a;char c1,c2; scanf(“%d%c%c”,&a,&c1;&c2); 若要求a、c1、c2的值分别为10、A和B,正确的数据输入是( )。 A)10AB B)10 A B C)10A B D)10 AB 6.若希望当a的值为奇数时,体现式的值为“真”,a的值为偶数时,体现式的值为“假”。则不能满足要求的体现式是( )。 A)a%2==1 B)!(a%2==0) C)!(a%2) D)a%2 7.若有定义:int a=2,b=3;float x=3.5,y=
3、2.5;则体现式float(a+b)/2+(int)x%(int)y的值为 ( ). A)3.5 B)3.0 C)2.5 D)2.0 8.如下程序的运行成果是( )。 void main() {int n=’e’; swithc(n--) {default:printf(”error”); case ’a’: case ’b’: printf(”good”);break; case ’c’: printf(”pass”); case ’d’: printf(”warn”); }} A)error B)g
4、ood C)error good D)warn 9.如下程序的运行成果是( )。 void main() {int sum=0,item=0; while(item<5) {item++; sum+=item; if(sum==5) break; } printf(”%d\n”,sum); } A)10 B)15 C)5 D)6 10.下面程序段的运行成果是( )。 int i=0,a[]={3,4,5,4,3}; do{ a[i]++; }while(a[++i]<5); for
5、i=0;i<5;i++) printf(”%d”,a[i]); A)4 5 6 5 4 B)3 4 5 4 3 C)4 5 5 5 4 D)4 5 5 4 3 11.若有定义:int a[2][3];则对数组元素的非法引用是( )。 A)a[0][1/2] B)a[1][1] C)a[4-4][0] D)a[0][3] 12.如下程序段运行后屏幕输出为( )。 char str[]=”ab\\cd”; printf(”%d”,strlen(str)); A)4 B)5 C)6 D)7 13.若有如下函数定义: int fun(
6、)
{ static int k=0;
return ++k;}
如下程序段运行后屏幕输出为( )。
int i;
for(i=1;i<=5;i++) fun();
printf(”%d”,fun());}
A)0 B)1 C)5 D)6
14.下面程序的输出成果是( )
#include
7、
15.有阐明语句:double *p,a;能通过scanf语句正确给输入项读入数据的程序段是( )。
A)*p=&a;scanf(”%lf”,p); B)*p=&a;scanf(”%lf”,*p);
C)p=&a;scanf(”%lf”,*p); D)p=&a;scanf(”%lf”,p);
16.下面程序的输出成果是( )
#include
8、 bc bc c ab
c abc bc abc
17.如下程序的运行成果是( )。
#include
9、 head … struct node{ int data; struct node *next; }; int fun(struct node *head) {int n=0; struct node *t=head; while(t!=NULL) { n++; t=t->next; } return n; } A)删除链表head中的所有结点 B)计算链表head中结点的个数 C)插入一个元素到链表head中 D)创建一个链表head 19.下面程序的输出成果为( )。 #i
10、nclude
11、 your name or you typed more parameters\n”); exit(1);} printf(”Hello %s\n”,argv[1]); } 在DOS命令行输入:cmdline harry<回车>,则输出成果是( )。 A) You forgot to type your name or you typed more parameters B) Hello harry C) Hello cmdline D) hello 二、改错题(共2小题,每题10分) 1.程序cmody071.c,其功效是从键盘输入三角形的三边长
12、求其面积,若三个边长不能组成三角形,则提示。
如 输入:6 9 11 输出: 26.98
#include
13、a[0]+a[1]+a[2])/2;
area=sqrt(s*(s-a[0])*(s-a[1])*(s-a[2]))l
printf(”area is %.2f\n”,area);}
else printf(”error.\n”);
getch();
}
2.程序cmody072.c其功效是求解百马百担问题。
有100匹马,驮100担货,大马驮3担,中马驮2担,两匹小马驮1担,问大、中、小马数可分别为多少?有多少种处理方案?
#include
14、/**/ {int large,middle,small,n=0; clrscr(); for(large=0;large<=33;large++) for(middle=0;middle<=50;middle++) {small=2*(100-3*large-2*middle); /**/if(large+middle+small=100)/**/ {n++; printf(”%d-->large:%d,middle:%d,small%d\n”,n,large,middle,small); } } return n
15、}
void main()
{int num;
num=fun();
printf(”\nThere are %d solutions.\n”,num);
getch();
}
三、填空题(共3小题,每题8分)
1.补充程序Ccon071.c,对函数,分别计算和的值。
如x=2.0,则输出:f(x+8)=86.000 f(sinx)=5.008
#include
16、
{double x,y1,y2;
clrscr();
printf(“Please input x:”);
scanf(“%lf”,&x);
y1=fun(x+8);
y2=fun(/**/ /**/);
printf(“\nf(x+8)=%.3lf”,y1);
printf(“\nf(sinx)=%.3lf”,y2);
getch();
}
2.补充程序Ccon072.c,计算,其中m、n为整数且m>n≥0。
#include
17、d n) {unsigned i; double p=1.0; for(i=1;i<=m;i++) /**/ /**/ for(i=1;i<=n;i++) /**/ /**/ for(i=1;i<=m-n;i++) p=p/I; return p; } void main() {clrscr(); printf(“p=%f\n”,fun(13,7)); getch(); } 3.补充程序Ccon073.c,函数findmax返回数组中的最大元素。 #include
18、 19、f(array[i]>max)max=array[i];
return max;
}
四、编程题(共2小题,每题8分)
1.打开程序cprog071.c,完成其中的f()函数,使其对输入的一个月工资数额,求应交税款,设应交税款的计算公式如下:
例如:输入:1825输出:f(1825)=11.25 输入:2700输出:f(2700)=85.00输入:5655输出:f(5655)=483.25
#include 20、in()
{ float x;
double y;
printf (”Please input x: \n”);
scanf(”%f”,&x);
y=f(x);
printf (”f(%.2f)=%.2f\n”,x,y);
getch();
}
2. 打开程序cprog072.c,完成其中的fun()函数,使程序输出4阶矩阵A中的各行中0之前的所有正数,遇到0则跳过该行,并计算这些输出正数之和。如矩阵A为
,则输出1,2,23,32 s=58。
#include 21、e COL 4
int fun(int a[][COL],int row int b[])
{ /**/
/**/
}
void main()
{int sss=0,b[16]={0};
int a[ROW][COL]={{1,2,-3,-4},{0,-12,-13,14},{-21,23,0,-24},{-31,32,-33,0}};
clrscr();
sss=fun(a,ROW,b);
printf(”\nSum of positive elements is %d \n”,sss);
getch();
}
一、选择题
1. 22、D 2.B 3.A 4.B 5.A 6.C 7.A 8.C 9.B 10.D
11.D 12.B 13.D 14.A 15.D 16.A 17.D 18.B 19.B 20.B
二、改错题
1. scanf(“%f”,&a[i]); if(a[0]+a[1]>a[2]&&a[1]+a[2]>a[0]&&a[0]+a[2]>a[1])
2. int fun() if(large+middle+small==100)
三、填空题
1. #include 23、0/i;
3. find max(a,sizeof(a)/sizeof(int)) max=*array或max=array[0]
四、编程题
1. doulbe y;
if(x<=1600) y=0;
if(x>1600&&x<=2100) y=(x-1600)*0.05;
if(x>2100&&x<=3100) y=(x-1600)*0.1-25;
if(x>3100) y=(x-1600)*0.15-125;
return y;
2. int i,j,s=0,k=0;
for(i=0;i






