一、单选题(每小题2分,共20分)
1. C语言源程序文件的缺省扩展名为( c )。
2.设x和y均为逻辑值,则x && y为真的条件是x和y(均为真)。
3. 在下列的符号常量定义中,正确的定义格式为( #define M3 10 )。
4. for循环语句能够被改写为( while )语句。
5. 在下面的一维数组定义中,错误的定义格式为(int a[]; )。
6.在下面的函数原型声明中,存在语法错误的是(int AA(int a; int b;); )。
7. 假定a为一个数组名,则下面存在错误的表达式为( *a++ )。
8. 假定有定义为“int a[10], x, *pa=a;”,若要把数组a中下标为3的元素值赋给x,则不正确的赋值为( x=*pa+3 )。
9.字符串"y=%d\n"的长度为__5__。
10. 向一个二进制文件中写入信息的函数为(fwrite() )。
二、填空题(每小题2分,共26分)
1.执行“printf("%c",'A'+3);”语句后得到的输出结果为_D_
2.短整数类型short int的长度为 2
3. 用类型关键字表示十进制常数3.26f的类型为_float
4. 假定y=10,则表达式++y*3的值为_33
5. 逻辑表达式(x==0 && y>5)的相反表达式为_(x!=0 || y<=5) 或:(x || y<=5)
6.若x=5,y=10,则x!=y的逻辑值为_1(真,true)
7. 假定二维数组的定义为“int a[3][5];”,则该数组所占存储空间的字节数为_60
8. 使用“typedef char BB[10][50];”语句定义_BB为含有10行50列的二维字符数组类型。
9. 字符串"a:\\xxk\\ff"的长度为9
10.假定p所指对象的值为25,p+1所指对象的值为46,则*++p的值为_46
11. 假定一个数据对象为int*类型,则指向该对象的指针类型为_int**
12.假定一个结构类型的定义为 “struct A{int a,b; struct A* c;};”,则该类型的理论长度为__12
13. 假定要访问一个结构对象x中的数据成员a,则表示方式为_x.a
三、写出下列每个程序运行后的输出结果(每小题6分,共30分)
1. #include<stdio.h>
void main()
{int x=3;switch(2*x+1) { case 4: printf("%d ",x); break;
case 7: printf("%d ",2*x); break;
case 10: printf("%d ",3*x); break;
default: printf("%s ","default");}}输出结果:6
2. #include<stdio.h>
void main() {int f=1,i; for(i=1;i<4;i++) f=3*f+1;
printf("%d ",f);}输出结果:40
3. #include<stdio.h>
void main() {int a[8]={12,39,26,41,55,63,72,40};
int i, c=0;for(i=0; i<8; i++)
if(a[i]%3==0) c++;
printf("%d\n",c);
}输出结果:4
4. #include<stdio.h>
#include<string.h>
void main( ) {
1
char s[]="123456";
int i, n=strlen(s) ;
for(i=0; i<n/2; i++) {
char c=s[i]; s[i]=s[n-1-i]; s[n-1-i]=c;
} printf("%s\n",s); }输出结果:654321
5. #include<stdio.h>
int LB(int *a, int n) { int *p,s=1;
for(p=a; p<a+n; p++) s*=*p;
return s;}
void main() {
int a[]={1,2,3,4};
printf("%d\n", LB(a,sizeof(a)/sizeof(int)));
// sizeof(a)为求出数组a所占用的存储空间的字节数}
输出结果:24
四、写出下列每个函数的功能(每小题6分,共12分)
1. #include<stdio.h>
int SA(int a, int b) {
if(a>b) return 1;
else if(a==b) return 0;
else return -1;
} 函数功能:比较两个整数a和b的大小,若a>b则返回1,若a==b则返回0,若a<b则返回-1。
2. void Output(struct IntNode *f) //f为单链表的表头指针
{
if(!f) return;
while(f) {
printf("%d ",f->data);
f=f->next;
}
printf("\n");
} 函数功能:遍历输出由f所指向的单链表中每个结点的值。
五、按题目要求编写程序(每小题6分,共12分)
1. 完善下面程序,该程序功能是从键盘上输入10个整数到一维数组a[10]中,然后按照下标从大到小的次序输出数组a[10]中的每个元素值,元素值之间用一个空格分开。
#include<stdio.h>
void main()
{ int a[10],i; //用i作为循环变量
printf("从键盘输入10个整数: \n");
//向下补充程序内容,用两个for循环实现
printf("\n");}
for(i=0; i<10; i++) scanf("%d",&a[i]); //3分
2
for(i=9; i>=0; i--) printf("%d ",a[i]); //6分
注:第1行中的&a[i]也可替换为a+i
2. 编写一个主函数,假定a和b的取值范围为:6≤a≤50,10≤b≤30,求出满足不定方程3a+2b=120的全部整数组解。如(20,30)就是其中的一组解。
void main()
{
int a,b; //1分
for(a=6;a<=50; a++) //2分
for(b=10;b<=30;b++)//3分
if(3*a+2*b==120) printf("(%d, %d)\n",a,b); //6分
一、单选题
1.在每个C语言程序中都必须包含有这样一个函数,该函数的函数名为( main )。
2.每个C语言程序文件的编译错误分为( 2 )类。
3. 字符串"a+b=12\n"的长度为( 7 )。
4. 在switch语句的每个case块中,假定都是以break语句结束的,则此switch语句容易被改写为( if )语句。
5. 在下面的do-while循环语句中,其循环体语句被执行的次数为( 10 )。 int i=0; do i++; while(i<10);
6. 将两个字符串连接起来组成一个字符串时,选用的函数为( strcat() )。
7. 若用数组名作为函数调用的实参,传递给形参的是( 数组的首地址 )。
8. 假定a为一个整数类型的数组名,整数类型的长度为4,则元素a[4]的地址比a数组的首地址大( 16 )个字节。
9. 假定s被定义为指针类型char *的变量,初始指向的字符串为"Hello world!",若要使变量p指向s所指向的字符串,则p应定义为( char *p=s; )。
10. 从一个数据文件中读入以换行符结束的一行字符串的函数为( fgets() )。
11. 由C语言目标文件连接而成的可执行文件的缺省扩展名为( exe )。
12. 设有两条语句为“int a=12; a+=a*a;”,则执行结束后,a的值为( 156 )。
13. 带有随机函数调用的表达式rand()%20的值在( 0~19 )区间内。
14. for循环语句“for(i=0; i<n; i+=2) S;”中循环体S语句被执行的次数为( (n+1)/2 )。
15. 在下列的字符数组定义中,存在语法错误的是( char a[10]='5'; )。
16. B 17. B 18. A 19. D 20. C
21. D 22. A 23. A 24. B 25. C
26. C 27. C 28. B 29. A 30. D
16. 若有一个函数原型为“double *function()”,则它的返回值类型为( 实数指针型 )。
17. 在C语言中,所有预处理命令都是以( # )符号开头的。
18. 假定整数指针p所指数据单元的值为30,p+1所指数据单元的值为40,则执行*p++后,p所指数据单元的值为( 40 )。
19. 若要使p指向二维整型数组a[10][20],则p的类型为( int(*)[20] )。
20. 表示文件结束符的符号常量为( EOF )
21. 程序运行中需要从键盘上输入多于一个数据时,各数据之间默认使用( 空格或回车 )符号作为分隔符。
22. 逻辑表达式(x>0 && x<=10)的相反表达式为( x<=0 || x>10 )。
23. 当处理特定问题时的循环次数已知时,通常采用( for )循环来解决。
24. 假定i的初值为0,则在循环语句“while(i<n) {s+=i*i; i++;}”中循环体被执行的总次数为( n )。
25. 假定一个二维数组的定义语句为“int a[3][4]={{3,4},{2,8,6}};”,则元素a[1][2]的值为( 6 )。
26. 在下列选项中,不正确的函数原型格式为( int Function(a); )。
27. 假定p是一个指向float型数据的指针,则p+1所指数据的地址比p所指数据的地址大( 4 )个字节。
28. 假定有定义为“int m=7, *p;”,则给p赋值的正确表达式为( p=&m )。 29假定指针变量p定义为“int *p=malloc(sizeof(int));”,要释放p所指向的动态存储空间,应调用的函数为( free(p) )。
3
30. C语言中的系统函数fopen()是( 打开 )一个数据文件的函数。
1.C语言中的每条简单语句以__;(或分号)_作为结束符。
2. C程序中的所有预处理命令均以_#_字符开头。
3. 当不需要函数返回任何值时,则应使用_void_标识符来定义函数类型。
4.十进制数25表示成符合C语言规则的十六进制数为_0x19。
5假定不允许使用逻辑非操作符,则逻辑表达式a>b || b==5的相反表达式为__a<=b && b!=5
6. 执行“typedef int DataType;”语句后,在使用int定义整型变量的地方也可以使用__DataType来定义整型变量。
7. 假定一维数组的定义为“char* a[8];”,则该数组所占存储空间的字节数为__32_。
8. 假定二维数组的定义为“double a[M][N];”,则该数组的列下标的取值范围在__0~N-1_之间。
9. 存储一个空字符串需要占用_1 _个字节。
10. strcpy函数用于把一个字符串_拷贝(复制)_到另一个字符数组空间中。
11. 程序的编译单位是一个_程序文件__。
12. 假定a是一个一维数组,则a[i]的指针访问方式为__*(a+i)_。
13. 执行int *p=malloc(sizeof(int))操作得到的一个动态分配的整型对象为_*p _。
14.执行“printf("%c",'A'+2);”语句后得到的输出结果为__ C_。
15.short int类型的长度为__2。
16. 用类型关键字表示十进制常数3.26f的类型为__float。
17. 假定y=10,则表达式++y*3的值为__33 。
18. 逻辑表达式(x==0 && y>5)的相反表达式为__(x!=0 || y<=5) 或:(x || y<=5) 。
19.若x=5,y=10,则x!=y的逻辑值为__1
20. 假定二维数组的定义为“int a[3][5];”,则该数组所占存储空间的字节数为__60。
21. 使用“typedef char BB[10][50];”语句定义__BB_为含有10行50列的二维字符数组类型。 22. 字符串"a:\\xxk\\数据"的长度为__11
23.假定p所指对象的值为25,p+1所指对象的值为46,则*++p的值为__46 。
24. 假定一个数据对象为int*类型,则指向该对象的指针类型为__int** 。
25.假定一个结构类型的定义为 “struct A{int a,b; A* c;};”,则该类型的长度为_12
26. 假定要访问一个结构对象x中的数据成员a,则表示方式为__x.a。
27. 用于输出表达式值的标准输出函数的函数名是__printf。
28.每个C语言程序文件在编译时可能出现有致命性错误,其对应的标识符为__error 29. 已知'A'?'Z'的ASCII码为65?90,当执行“int x='C'+3;”语句后x的值为_70。
30. 表达式(int)14.6的值为__14。
31. 假定不允许使用逻辑非操作符,则关系表达式x+y>5的相反表达式为_x+y<=5 32. 假定x=5,则执行“a=(x?10:20);”语句后a的值为___10。
33. 假定一维数组的定义为“char* a[M];”,则该数组所占存储空间的字节数为___4*M。
34. 存储字符串"a"需要至少占用存储器的_2_个字节。
35. strlen()函数用于计算一个字符串的_长度
36. 在C语言中,一个函数由函数头和___函数体_这两个部分组成。
37.假定p所指对象的值为25,p+1所指对象的值为46,则执行表达式*(p++)后,p所指对象的值为_ 46。
38. 假定p是一个指向整数对象的指针,则用__ &p_表示指针变量p的地址。
39. 与结构成员访问表达式p->name等价的访问表达式为_(*p).name。
三、写出下列每个程序运行后的输出结果
1. #include<stdio.h>
void main()
{
4
int x=5;
switch(2*x-1) {
case 4: printf("%d ",x); break;case 7: printf("%d ",2*x); break;case 10: printf("%d ",3*x); break;default: printf("%s ","default"); }
printf("%s\n","switch end.");
}
输出结果default switch end.
2. #include<stdio.h>
void main() {
int f1,f2,i;
f1=1;
printf("%d ",f1);
for(i=2;i<=5;i++) {
f2=3*f1+1;
printf("%d ",f2);
f1=f2;
}
printf("\n");
}
输出结果1 4 13 40 121
3. #include<stdio.h>
void main() {
int a[10]={12,39,26,41,55,63,72,40,83,95}; int i, i1=0, i2=0;
for(i=0;i<10;i++)
if(a[i]%2==1) i1++; else i2++; printf("%d %d\n",i1,i2);
}
输出结果6 4
4. #include<stdio.h>
#include<string.h>
void main( ) {
char s[15]="567891234";
int i, n=strlen(s) ;
for(i=0; i<n/2; i++) {
char c=s[i];
s[i]=s[n-1-i];
s[n-1-i]=c;
}
printf("%s\n",s);
}
5
输出结果432198765
5. #include<stdio.h>
int LB(int *a, int n) {
int i,s=1;
for(i=0;i<n;i++) s*=*a++;
return s;
}
void main() {
int a[]={1,2,3,4,2,4,5,2};
int b=LB(a,4)+LB(a+3,3);
printf("b=%d\n",b);
}
输出结果b=56
6. #include<stdio.h>
void main() {
int i,s=0;
for(i=1;i<6;i++) s+=i*i;
printf(“s=%d\n”,s);
}
输出结果s=55
7. #include<stdio.h>
#define N 6
void main()
{
int i,a[N]={2,5,8,10,15,21};
for(i=0; i<N; i++)
if(a[i]%5) printf("%d ",a[i]);
printf("\n");
}
输出结果2 8 21
8. #include<stdio.h>
#include<string.h>
void main() {
int i;
unsigned int len;
char* a[5]={"student","worker","cadre","soldier","zzeasan123"}; len=strlen(a[0]);
for(i=1; i<5; i++)
if(strlen(a[i])>len) len=strlen(a[i]);
printf("%d\n",len);
}
输出结果10
6
9. #include<stdio.h>
void main()
{
int a,b;
for(a=2,b=3; b<20;) {
printf("%d %d ",a,b);
a=a+b;
b=a+b;
}
printf("%d %d\n",a,b);
}
输出结果 2 3 5 8 13 21
10. #include<stdio.h>
void LE(int* a, int* b) {
int x=*a;
*a=*b; *b=x;
}
void main() {
int x=15, y=26;
printf("%d %d\n",x,y);
LE(&x,&y);
printf("%d %d\n",x,y);
}
输出结果15 26 26 15
11. #include<stdio.h>
void main() {
int i, s=0;
for(i=1;;i++) {
if(s>30) break;
if(i%2==0) s+=i;
}
printf("s=%d\n",s);
}
输出结果s=42
12. #include<stdio.h>
void main() {
int a[9]={36,25,48,24,55,40,18,66,20}; int i, b1, b2;
b1=b2=a[0];
for(i=1; i<9; i++) {
if(a[i]>b1) b1=a[i];
if(a[i]<b2) b2=a[i];
}
7
printf("%d %d\n",b1,b2);
}
输出结果66 18
13. #include<stdio.h>
void SB(char ch) {
switch(ch) {
case 'A': case 'a':
printf("WW "); break;
case 'B': case 'b':
printf("GG "); break;
default:
printf("BB "); break;
}
}
void main() {
char a1='a',a2='B',a3='f';
SB(a1);SB(a2);SB(a3);
printf("\n");}
输出结果WW GG BB
14. #include<stdio.h>
#define M 6
void main(){ int i,x;
int a[M]={10,15,22,37,46,58};
for(i=0; i<M/2; i++) {x=a[i]; a[i]=a[M-1-i]; a[M-1-i]=x;} for(i=0; i<6; i++) printf("%d ",a[i]);
printf("\n");
}
输出结果58 46 37 22 15 10
15. #include<stdio.h>
struct Worker {
char name[15]; int age; float pay;
};
void main() {
struct Worker x={"wanghua",52,2350};
struct Worker y, *p;
y=x; p=&x;
printf("%d %7.2f\n", y.age+p->age, p->pay+20); }
输出结果104 2370.00
16. #include<stdio.h>
void main() {
int i,j,k=0;
for(i=0; i<5; i++)
for(j=i; j<5; j++) k++;;
8
printf("%d\n",k);
}
输出结果 15
17. #include<stdio.h>
void main()
{
int x=60;
int i=2, p=1;
while(1) {
if(x%i==0) {p*=i; x/=i;} if(i<x) i++; else break; }
printf("%d\n",p);
}
输出结果30
18. #include<stdio.h>
void main() {
int a[8]={76,63,54,62,40,75,90,58}; int i;
for(i=0; i<8; i++)
if(a[i]>70) printf("%d ",a[i]); printf("\n");}
输出结果 76 75 90
19. #include<stdio.h>
void WF(int x, int y) {
x=x+y;
y+=x;
printf("%d %d\n",x,y);} void main() {
int x=3, y=8;
WF(x,y);}
输出结果11 19
20. #include<stdio.h>
int LA(int *a, int n) {
int i,s=0;
for(i=0;i<n;i++) s+=a[i]; return s;
}
void main() {
int a[5]={3,4,6,10,20};
int b=LA(a,5);
int c=LA(a+2,3);
printf("%d %d\n",b,c);} 输出结果 43 36
9
四、写出下列每个函数的功能
1. #include<math.h>
int SG(int x) { //x为大于等于2的整数
int a=(int)sqrt(x); //sqrt(x)取x的平方根
int i=2;
while(i<=a) {
if(x%i==0) break;
i++;
}
if(i<=a)return 0; else return 1;
}
判断x是否为一个素数,若是则返回1,否则返回0。
2. int FindMax(struct IntNode *f) //f为一个单链表的表头指针 {
int x;
if(!f) {printf("单链表为空\n"),exit(1);}
x=f->data;
f=f->next;
while(f) {
if(f->data>x) x=f->data;
f=f->next;
} return x;}
假定struct IntNode的类型定义为:
struct IntNode { int data; struct IntNode* next;};
求出由f所指向的单链表中所有结点的最大值。
3. #include<stdio.h>
int SA(int a, int b) {
if(a>b) return 1;
else if(a==b) return 0;
else return -1;
}
比较两个整数a和b的大小,若a>b则返回1,若a==b则返回0,若a<b则返回-1。
4. void Output(struct IntNode *f) //f为单链表的表头指针
{
if(!f) return;
while(f) {
printf("%d ",f->data);
f=f->next;
}
printf("\n");
}
假定struct IntNode的类型定义为:
struct IntNode { int data; struct IntNode* next;};
10
遍历并输出由f所指向的单链表中每个结点的值。
5. int SC(int a, int b, int c) {
if(a>=b && a>=c) return a;
if(b>=a && b>=c) return b;
return c;}
求出a,b,c三个数中的最大值并返回。
6. int* LI(int n) {
int* a=malloc(n*sizeof(int));
int i;
for(i=0;i<n;i++) scanf("%d",a+i);
return a;
}首先建立一个动态整型数组a[n],接着从键盘上输入n个整数到a[n]中,最后返回数组a[n]的首地址。
7. int WC(int a[], int n, int k) {
int i, c=0;
for(i=0;i<n;i++)
if(a[i]>=k) c++;
return c;
} 统计并返回一维整型数组a[n]中大于等于k的值的个数
8. void QA(struct Worker a[], int n)
{ int i;
for(i=0; i<n; i++)
scanf("%s %d %f", a[i].name, &a[i].age, &a[i].pay);}
假定结构类型struct Worker 的定义如下:
struct Worker { char name[15]; int age; float pay;};
从键盘上为具有struct Worker类型的数组a[n]输入n个记录
五、按题目要求编写程序或函数
1. 编写一个程序,输出50以内(含50)的、能够被3或者5整除的所有整数。
#include<stdio.h>
void main()
{
int i;
for(i=3; i<=50; i++)
if(i%3==0 || i%5==0) printf("%d ",i);
printf("\n");
}
2. 编写一个递归函数“int FF(int a[], int n)”,求出数组a中所有n个元素之积并返回。
int FF(int a[], int n)
{
if(n<=0) {printf("n值非法\n"),exit(1);}
if(n==1) return a[n-1];
else return a[n-1]*FF(a,n-1);
}
3. 编写一个程序,利用while循环,计算并打印输出1?111??...?的值,其中正整数n值由键盘输入。假定求和23n
11
变量用sum表示,计数变量用i表示,sum、i和n均定义为全局变量,sum和i的初值分别被赋予0和1。#include<stdio.h> int n,i=1;
double sum=0;
void main()
{
scanf("%d",&n);
while(i<=n) sum+=(double)1/i++;
printf("sum=%lf\n",sum);
}
4. 根据函数原型“void DD(int a[], int n, int MM)”编写函数定义,利用双重循环查找并打印输出数组a[n]中任何两个元素的值等于MM值的元素值。假定a[i]+a[j]等于MM,则输出格式为:(a[i],a[j])。
void DD(int a[], int n, int MM)
{
int i,j;
for(i=0; i<n; i++)
for(j=i+1; j<n; j++)
if(a[i]+a[j]==MM) printf("%d, %d\n", a[i],a[j]);
}
5. 编写一个程序,计算1+3+3+...+3的值并输出,假定分别用i,p,s作为循环变量、累乘变量和累加变量的标识符。 #include<stdio.h>
void main()
{
int i;
int p=1;
int s=1;
for(i=1;i<=10;i++) {p*=3; s+=p;}
printf("%d\n",s);
}
6. 根据函数原型“int FF(int a[], int n)”,编写函数定义,计算并返回数组a[n]中所有元素之和。
int FF(int a[], int n)
{
int i,sum=0;
for(i=0; i<n; i++) sum+=a[i];
return sum;
}
7. 根据函数原型“double Mean(double a[M][N],int m,int n)”,编写函数定义,要求返回二维数组a[m][n]中所有元素的平均值。假定在计算过程中采用变量v存放累加值和最后的平均值。
double Mean(double a[M][N],int m,int n)
{
int i,j;
double v=0.0;
for(i=0; i<m; i++)
for(j=0; j<n; j++) v+=a[i][j];
v/=m*n; 210
12
return v;
}
8. 根据函数原型“int MM(int a[],int m)”,编写函数定义,计算并返回数组a[m]中元素最大值和最小值之差。 int MM(int a[],int m)
{
int i,x1,x2;
x1=x2=a[0];
for(i=1; i<m; i++) {
if(a[i]>x1) x1=a[i];
if(a[i]<x2) x2=a[i];
}
return x1-x2;
}
13
www.99jianzhu.com/包含内容:建筑图纸、PDF/word/ppt 流程,表格,案例,最新,免费下载,施工方案、工程书籍、建筑论文、合同表格、标准规范、CAD图纸等内容。