printf(“%d,%d,%d\n”,a,b,c);
}
2. switch((s>0)&&(s<=10))
{case 1: switch ((s>=3)&&(s<=6))
{ case 1: x=2; break;
case 0: switch (s>1)||(s>8))
{ case 1: x=3; break;
case 0: x=1; break;
}
} break;
case 0: x=0; break;
}
循环结构答案
一、选择题
1.B 2.A 3.A 4.C 5.A 6.B 7.A 8.C 9.D 10.D
二、填空题
1. x1 x1/2-2
2. ch=getchar() ch>=’A’&&ch<=’Z’
3. s=s+t*i t=-t
三、阅读下列程序,写出程序运行的输出结果
1.852
2. 8921
3. 5
4. SUM=2468
四、程序改错
1.main()
{ int i=200,n=0; /*n用来记录每行已打印数的个数*/
while(i<=300)
{if(i%7==0)
{ //break;
printf("%5d",i); n=n+1;
if(n==5) /*满5个换行*/
{ printf("\n"); n=0; }
}
i++; } }
2). main( )
{ int i,s=0,t=1;
for(i=1;i<=7;i++)
{ t=t*i; s=s+t; }
printf("sum=%d\n",s);
}
五、程序设计题
1. main()
{int x,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(“%d\n”,x); }
}
2. main()
{ int i,s=0,f=1;
for(i=2;i<80;i++)
{s=s+f*(i-1)/i; f=-f;}
printf(s=%f\n”,s);
}
六、选做题
1. main()
{ float s=0,m=2.0,n=1.0,p;
int i;
for(i=1;i<=20;i++)
{s=s+m/n; p=m; m=m+n; n=p;}
printf(s=%f\n”,s);
}
2.#include
main( )
{ int i,j,k,s=1;
for(i=1;i<=20;i++)
for(j=1;j<=50;j++)
{ k=100-i*5-j*2;
if(k>=0)
{ printf(“%2d %2d %2d”,i,j,k);
s=s+1;
if(s%5==0) printf(“\n”);
}
}
}
第7章 数组习题
A卷
1. 单项选择题
(1) int a[4]={5,3,8,9};其中 a[3]的值为( )。D
A. 5 B. 3 C. 8 D. 9
(2) 以下 4 个字符串函数中,( )所在的头文件与其他 3 个不同。A
A. gets B. strcpy C. strlen D. strcmp
(3) 以下 4 个数组定义中,( )是错误的。 D
A. int a[7]; B. #define N 5 long b[N]; C. char c[5]; D. int n,d[n];
(4) 对字符数组进行初始化,( )形式是错误。 B
A. char c1[ ]={'1', '2', '3'}; B. char c2[ ]=123; C. char c3[ ]={ '1', '2', '3', '\0'}; D. char c4[ ]="123";
(5) 在数组中,数组名表示( )。 A
A. 数组第 1 个元素的首地址 B.数组第 2 个元素的首地址
C. 数组所有元素的首地址 D.数组最后 1 个元素的首地址
(6) 若有以下数组说明,则数值最小的和最大的元素下标分别是( )。 B
int a[12] ={1,2,3,4,5,6,7,8,9,10,11,12};
A. 1,12 B. 0,11 C. 1,11 D. 0,12
(7) 若有以下说明,则数值为 4 的表达式是( )。 D
int a[12] ={1,2,3,4,5,6,7,8,9,10,11,12}; char c=’a’, d, g ;
A. a[g-c] B. a[4] C. a['d'-'c'] D. a['d'-c]
(8) 设有定义:char s[12] = "string" ; 则printf( "%d\n",strlen(s)); 的输出是( )。 A
A. 6 B. 7 C. 11 D. 12
(9) 设有定义:char s[12] = "string"; 则printf("%d\n ", sizeof(s)); 的输出是( )。 D
A. 6 B. 7 C. 11 D. 12
(10) 合法的数组定义是( )。 A
A. char a[ ]= "string " ; B. int a[5] ={0,1,2,3,4,5}; C. char a= "string " ; D. char a[ ]={0,1,2,3,4,5}
(11) 合法的数组定义是( )。 D
A. int a[3][ ]={0,1,2,3,4,5}; B. int a[ ][3] ={0,1,2,3,4};
C. int a[2][3]={0,1,2,3,4,5,6}; D. int a[2][3]={0,1,2,3,4,5,};
(12) 下列语句中,正确的是 ( )。D
A. char a[3][ ]={'abc', '1'}; B. char a[ ][3] ={'abc', '1'};
C. char a[3][ ]={'a', "1"}; D. char a[ ][3] ={ "a", "1"};
(13) 下列定义的字符数组中,输出 printf("%s\n", str[2]) ;的输出是( )。 C
static str[3][20] ={ "basic", "foxpro", "windows"};
A. basic B. foxpro C. windows D. 输出语句出错
(14) 下列各语句定义了数组,其中哪一个是不正确的( )。 C
A. char a[3][10]={"China","American","Asia"}; B. int x[2][2]={1,2,3,4};
C. float x[2][ ]={1,2,4,6,8,10}; D. int m[][3]={1,2,3,4,5,6};
(15) 数组定义为 int a[3][2]={1,2,3,4,5,6},值为6的数组元素是( )。 B
A. a[3][2] B. a[2][1] C. a[1][2] D. a[2][3]
(16) 下面的程序中哪一行有错误( )。D
#include
main()
{
float array[5]={0.0}; //第A行
int i;
for(i=0;i<5;i++)
scanf("%f",&array[i]);
for(i=1;i<5;i++)
array[0]=array[0]+array[i];//第B行
printf("%f\n",array[0]); //第C行
}
A. 第A行 B. 第B行 C. 第C行 D. 没有
(17) 下面哪一项是不正确的字符串赋值或赋初值的方式( )。 C
A. char *str; str="string";
B. char str[7]={'s','t','r','i','n','g'};
C. char str1[10];str1="string";
D. char str1[]="string",str2[]="12345678";
(18) 若有以下说明和语句,则输出结果是哪一项( )。C
(strlen(s)为求字符串s的长度的函数)
char s[12]="a book!";
printf("%d",strlen(s));
A. 12 B. 8 C. 7 D. 11
(19) 若有以下说明和语句,则输出结果是( )。B
(strlen(s)为求字符串s的长度的函数)
char sp[]="\t\v\\\0will\n";
printf("%d",strlen(sp));
A. 14 B. 3 C. 9 D. 字符串中有非法字符
(20) 若有以下说明和语句,则输出结果是( )。 C
char str[]="\"c:\\abc.dat\"";
printf("%s",str);
A. 字符串中有非法字符 B. \"c:\\abc.dat\" C. "c:\abc.dat" D. "c:\\abc.dat"
2. 填空题
(1) C 语言中,数组的各元素必须具有相同的 ,元素的下标下限为 ,下标必须是正整数、0、或者 。但在程序执行过程中,不检查元素下标是否 。
数据类型,0,符号常量,越界
(2) C 语言中,数组在内存中占一片 的存储区,由 代表它的首地址。数组名是一个 常量,不能对它进行赋值运算。连续,数组名,地址
(3) 执行 static int b[5], a[ ][3] ={1,2,3,4,5,6}; 后,b[4] = ,a[1][2] = 。 0,6
(4) 设有定义语句 static int a[3][4] ={{1},{2},{3}}; 则 a[1][0]值为 ,a[1][1] 值为 ,a[2][1]的值为 。 2,0,0
(5) 如定义语句为 char a[ ]= "windows",b[ ]= "95";,语句 printf("%s",strcat(a,b));的输出结果为 。Windows95
(6) 根据以下说明,写出正确的说明语句:men是一个有10个整型元素的数组。
step是一个有4个实型元素的数组,元素值分别为1.9, -2.33, 0, 20.6。
grid是一个二维数组,共有4行,10列整型元素。
int mesh[10]; float step[4] = {1.9, -2.33, 0, 20.6}; int grid[4][10];
(7) array是一个一维整形数组,有10个元素,前6个元素的初值是9,4,7,49,32,-5,正确的说明语句为:
。该数组下标的取值范围是从___到___(从小到大)。用scanf函数输入数组的第二个元素表示为: 。用赋值语句把39存入第一个元素表示为: 。
把第六个和第四个元素之和存入第一个元素表示为: 。
int array[10] = {9,4,7,49,32,-5}; 0 9 scanf("%d",&array[1]); array[0] = 39; array[0]= array[5]+array[3];
(8) 写出以下初始化数组的长度:①int chn[3];数组chn的长度为___。②float isa[]={1.0,2.0,3.0,4.0,5.0};
数组isa的长度为___。③int doom[8];数组doom的长度为___。④float pci[4][2];数组pci的长度为___。
⑤int ast[3][3];数组ast的长度为___。⑥int att[3][4];数组att的长度为___。
⑦float dell[][3]={{1,4,7},{2,5},{3,6,9}};数组dell的长度为___。 6 20 16 32 18 24 36
(9) 若有以下整型的a数组,数组元素和它们得值如下所示:
数组元素: a[0] a[1] a[2] a[3] a[4] a[5] a[6] a[7] a[8] a[9]
元素的值: 9 4 12 8 2 10 7 5 1 3
①请写出对该数组的说明,并赋以上初值。
②该数组的最小下标值为___,最大下标值为___。
③写出下面各式的值:a[a[9]]的值为___ ;a[a[4]+a[8]]的值为___。
int a[10]={9,4,12,8,2,10,7,5,1,3}; 0 9 8 8
(10) 字符串"ab\n\\012/\\\""的长度为___。10
3. 判断题
( × )(1) C允许对数组的大小作动态定义,即可用变量定义数组的大小。
( × )(2) 字符数组不要求它的最后一个字符为‘\0’,甚至可以不包含‘\0’。
( × )(3) 数组定义 int a[10]; 也可以写成 int a(10); 。
( √ )(4) 在对全部数组元素赋初值时,可以不指定数组长度。
( × )(5) 定义s为5×6(5行6列)的数组可写成 float a[5,6];
( √ )(6) 数组定义 int a[10]; 表示数组名为a,此数组有10个元素。
( × )(7) 数组定义 int a[10]; 表示数组名为a,此数组有10个元素,第10个元素为a[10]。
( √ )(8) static char c[]={“a book”}; 与static char c[]=“a book”; 等价。
( × )(9) static char c[]={'a' ,' ','b','o','o','k','\0'};与 static char c[]={'a' ,' ' ,'b','o','o','k'}; 等价。
( × )(10) 设已有说明:static char c1[10],c2[10]; 下面程序片段是合法的。c1={“book”}; c2=c1;
4. 程序填空题
(1) 输入 20 个数,输出它们的平均值,输出与平均值之差的绝对值为最小的数组元素。请填空。
#include
void main( )
{
float a[20],pjz=0,s,t; int i,k;
for(i=0;i<20;i++) pjz+=a[i];
s=fabs(a[0]-pjz);
for(i=1;i<20;i++)
if(fabs(a[i]-pjz)
{
s=fabs(a[i]-pjz); t=a[i];
}
}
--------------------------------------------------------------------------------
for(i=0;i<20;i++) scanf(“%f”,&a[i]); pjz/=20; printf(“%f,%f\n”,piz,t);
(2) 以下程序以每行 10个数据的形式输出 a 数组,请填空。
void main( )
{
int a[50],i;
printf("输入50个整数:");
for(i=0; i<50; i++) scanf( "%d", );
for(i=1; i<=50; i++)
{ if( )
printf( "%3d\n" , ) ;
printf( "%3d",a[i-1]);
}
}
&a[i] i%10==0 a[i-1]
(3) 下面程序的功能是输出数组 s 中最大元素的下标,请填空。
void main( )
{
int k, p;
int s[ ]={1,-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) 这个程序输入了20个数存放在一个数组中,并且输出其中最大者与最小者、20个数的和及它们的平均值。请填空。
void main()
{
char array ;
int max,min,average,sum;
int i;
for(i=0;i< ;i++)
{
printf("请输入第%d个数:",i+1);
scanf("%d", );
}
max=array[0];
min=array[0];
for(i=0;i<= ;i++)
{
if(max
if(min>array[i])
sum= ;
}
average = ;
printf("20个数中最大值是%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)
#include
#include
void main( )
{
char s[80];
int i ;
for(i=0; i<80; i++)
{
s[i]=getchar( );
if(s[i]=='\n') break;
}
s[i]='\0'; i=0;
while(s[i]) putchar(s[i++]);
putchar(‘\n’);
}
从键盘输入一个字符串,并逐一输出
(2)
#include
#include
void main( )
{
char str[10][80], c[80];
int i;
for(i=0; i<10; i++) gets(str[i]);
strcpy(c, str[0]) ;
for(i=1; i<10; i++) if(strlen(c)
printf( "%s\n", c);
printf( "%d\n", strlen (c));
}
从键盘输入若干字符串,找到其中最长的一个输出及它的长度
(3)
#include
#include
void main( )
{
char a[10][80], c[80];
int i, j, k;
for(i=0; i<10; i++) gets(a[i]);
for(i=0; i<9; i++)
{
k=i ;
for(j=i+1; 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) 阅读程序,写出运行结果
#include
void main( )
{
int a[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 ",a[i]);
}
printf("\n");
}
4 25 27 16
(5) 阅读程序,写出运行结果。
#include
void main( )
{
char a[8],temp; int j,k;
for(j=0;j<7;j++) a[j]='a'+j; a[7]='\0';
for(j=0;j<3;j++)
{
temp=a[6];
for(k=6;k>0;k--) a[k]=a[k-1];
a[0]=temp;
printf("%s\n",a);
}
}
gabcdef
fgabcde
efgabcd
(6) 阅读下列程序,写出程序运行的输出结果。
#include
#include
void main( )
{
char str1[ ]="*******";
for(int i=0;i<4;i++)
{
printf("%s\n",str1);
str1[i]=' ';
str1[strlen(str1)-1]='\0';
}
}
*******
*****
***
*
(7) 该程序的运行结果是: min= ,m= ,n= 。
void main()
{
float array[4][3]={
{3.4,-5.6,56.7},
{56.8,999.,-.0123},
{0.45,-5.77,123.5},
{43.4,0,111.2}
};
int i,j;
int min;
int m,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("min=%d,m=%d,n=%d\n",min,m,n);
}
-5.77 2 1
(8) 写出下面这个程序的输出结果:
void main()
{
char str[]="ABCDEFGHIJKL";
printf("%s\n",str); 屏幕上显示
printf("%s\n",&str[4]); 屏幕上显示
str[2]=str[5];
printf("%s\n",str); 屏幕上显示
str[9]='\0';
printf("%s\n",str); 屏幕上显示
}
ABCDEFGHIJKL
EFGHIJKL
ABFDEFGHIJKL
ABFDEFGHI
(9) 读懂下面的程序并填空。
void main()
{
char str[80];
int i=0;
gets(str);
while(str[i]!=0)
{
if(str[i]>='a'&&str<='z')
str[i]-=32;
i++;
}
puts(str);
}
程序运行时如果输入 upcase, 屏幕显示
程序运行时如果输入 Aa1Bb2Cc3, 屏幕显示
UPCASE
AA1BB2CC
第8章 函数习题
A卷
1. 单项选择题
(1)C 语言总是从 函数开始执行。 A
A. main B. 处于最前的 C.处于最后的 D. 随机选一个
(2)函数在定义时,省略函数类型说明符,则该函数值的类型为 。A
A. int B. float C. long D. double
(2)以下 函数,真正地没有返回值。 B
A. int a(){int a=2;return (a);} B. void b(){printf("c");}
C. int a(){int a=2;return a;} D. 以上都是
(3)在 C 语言中,有关函数的说法,以下正确的是 。 A
A. 函数可嵌套定义,也可嵌套调用 B. 函数可嵌套定义,但不可嵌套调用
C. 函数不可嵌套定义,但可嵌套调用 D. 函数不可嵌套定义,也不可嵌套调用
(4)以下函数调用语句中,含有实参的个数为 。C
fun((2,3),(4,5+6,7));
A. 1 B. 2 C. 5 D. 6
(5)函数调用可以在 。 D
A. 函数表达式中 B. 函数语句中 C. 函数参数中 D. 以上都是
(6)被调函数返回给主调函数的值称为 。C
A. 形参 B. 实参 C. 返回值 D. 参数
(7) ,可以不进行函数类型说明。 D
A. 被调函数的返回值是整型或字符型时 B. 被调函数的定义在主调函数定义之前时
C. 在所有函数定义前,已在函数外预先说明了被调函数类型 D. 以上都是
(8)被调函数通过 语句,将值返回给主调函数。 D
A. if B. for C. while D. return
(9)被调函数调用结束后,返回到 。 D
A.主调函数中该被调函数调用语句处
B.主函数中该被调函数调用语句处
C.主调函数中该被调函数调用语句的前一语句
D.主调函数中该被调函数调用语句的后一语句
(10)以下对 C语言函数的有关描述中,正确的是 。A
A. 在 C 中,调用函数时,只能把实参的值传送给形参,形参的值不能传送给实参
B. C函数既可以嵌套定义又可递归调用
C. 函数必须有返回值,否则不能使用函数
D. C程序中有调用关系的所有函数必须放在同一个源程序文件中
(11)C 语言中函数的隐含存储类型是 。 C
A. auto B. static C. extern D. 无存储类型
(12)能把函数处理结果的两个数据返回给主调函数,在下面的方法中不正确的是 。A
A. return 这两个数 B. 形参用两个元素的数组
C. 形参用两个这种数据类型的指针 D. 用两个全局变量
(13)C语言可执行程序从什么地方开始执行 ( )。 C
A. 程序中第一条可执行语句 B. 程序中第一个函数
C. 程序中的main函数 D. 包含文件中的第一个函数
(14)有一个函数原型如下所示,则该函数的返回类型为( ) 。 C
abc(float x,float y);
A. void B. double C. int D. float
2. 填空题
(1) 变量的作用域主要取决于变量 ,变量的生存期既取决于变量 ,又取决于变量 。 所处的位置,所处的位置,存储类型
(2) 说明变量时,若省略存储类型符,系统默认其为 存储类别,该存储类别的类型符为: 。动态,auto
(3) 静态型局部变量的作用域是 ,生存期是 。它所在的局部,整个程序
(4) 函数中的形参和调用时的实参都是数组名时,传递方式为 ,都是变量时,传递方式为 。 址传递,值传递
(5) 函数的形式参数的作用域为 ,全局的外部变量和函数体内定义的局部变量重名时, _________变量优先。 该函数中,局部
(6) 若自定义函数要求返回一个值,则应在该函数体中有一条 语句,若自定义函数要求不返回一个值,则应在该函数说明时加一个类型说明符 。 return,void
(7) 若函数的形式参数是指针类型,则实参可以是 或 。指针,数组名
(8) 函数的参数为 char *类型时,形参与实参结合的传递方式为 。址传递
(9) 函数的实参为常量时,形参与实参结合的传递方式为 。值传递
(10) 下面这个函数的功能是求两个整数的积,并通过形参传回结果,请填空。int int int* *result
void mul(___x,___y,___result)
{
___=x*y;
}
3. 判断题
( × )(1) 函数说明指的是在程序中设定一个函数模块。
( √ )(2) 形参只有在被调用时才分配存储空间。
( × )(3) 在C的函数中,最好使用全局变量。
( × )(4) 在调用函数时,实参传值给形参,调用结束时,形参值传给实参。
( √ )(5) 所有函数定义都是并行的,相互独立的。
( × )(6) 函数的隐含存储类型是extern。
( × )(7) 形参可以是常量、变量或表达式。
( × )(8) 函数调用可以作为一个函数的形参。
( √ )(9) C语言规定,实参应与其对应的形参类型一致。
( × )(10) 定义函数时,形参的类型说明可以放在函数体内。
4. 程序填空题
(1) 对数组按值从大到小的顺序排序后输出,请填空。
#include
void main()
{
float a[7]={2,6,3,8,3,12,9};
int i ;
void sort(float*,int);
;
for(i=0;i<7;i++) printf("%f ",a[i]);
printf("\n");
}
void sort( )
{
int i,j,k; float t;
for(i=0;i
{
k=i;
for(j=i+1;j
if( ) k=j;
{ t=*(p+i); *(p+i)=*(p+k); *(p+k)=t; }
}
}
sort(a,7) float* p,int n *(p+k)<*(p+j) if(k!=i)
(2) 下列函数在 n 个元素的一维数组中,找出最大值、最小值并传送到调用函数,请填空。
#include
void find(float *p, int max, int min, int n)
{
int k;
*max=*p;
for(k=1;k
{
t=*(p+k);
if( ) *max=t;
if(t<*min) *min=t;
}
}
float t; *min=*p; *max
B卷
5. 写出下列程序运行结果
(1)
main()
{
int i=1,p;
p=fun(i,i+1);
printf("%d\n",p);
}
int fun(int a,int b)
{
int f;
if(a>b)
f=1;
else if(a==b)
f=0;
else
f=-1;
return f;
}
-1
(2)键盘输入 abcdef
#include
void fun( )
{
char c ;
if((c=getchar( ))!='\n')
fun( ) ;
putchar(c);
}
void main( )
{ fun( ); }
fedcba
(3)
#include
#define C 5
int x=1,y=C;
void main( )
{
int x;
x=y++; printf("%d %d\n", x,y);
if(x>4) { int x ; x=++y; printf("%d %d\n",x,y) ; }
x+=y--;
printf("%d %d\n",x,y);
}
5 6
7 7
12 6
(4)
#include
int c , a=4 ;
func(int a , int b)
{ c=a*b ; a=b-1 ; b++ ; return (a+b+1) ; }
void main( )
{
int b=2 , p=0 ; c=1 ;
p=func(b , a) ;
printf("%d,%d,%d,%d\n", a,b,c,p) ;
}
4,2,8,9
(5)
unsigned fun6(unsigned num)
{
unsigned k=1;
do { k*=num%10; num/=10; }
while(num);
return k;
}
void main( )
{
unsigned n=26;
printf("%d\n", fun6(n));
}
12
(6)
#include
int max(int a,int b);
main()
{
int x,y,z,t,m;
scanf("%d,%d,%d",&x,&y,&z);
t=max(x,y);
m=max(t,z);
printf("%d",m);
}
int max(int a,int b)
{
if(a>b)
return(a);
else
return(b);
}
运行时若输入:10,15,9 则输出:___ 15
运行时若输入:300,129,300 则输出:___ 300
(7)
#include
long sum(int a,int b);
long factorial(int n);
main()
{
int n1,n2;
long a;
scanf("%d,%d",&n1,&n2);
a=sum(n1,n2);
printf("a=%1d",a);
}
long sum(int a,int b)
{
long c1,c2;
c1=factorial(a);
c2=factorial(b);
return(c1+c2);
}
long factorial(int n)
{
long rtn=1;
int i;
for(i=1;i<=n;i++)
rtn*=i;
return(rtn);
}
运行时若输入:2,3 则输出:___ 8
运行时若输入:0, 5 则输出:___ 121
(8)
#include
int s();
int x,y;
main()
{
int n;
x=1;y=2;
n=s();
printf("x=%d,y=%d,n=%d",x,y,n);
}
int s()
{
int z;
x=3;y=4;
z=x+y;
return(z);
}
程序运行后输出:___ 3,4,7
(9) 以下程序的输出结果是a=___,b=___,c=___。
#include
int func(int a,int *p);
void main()
{
int a=1,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);
}
int func(int a,int *p)
{
a++;
*p=a+2;
return(*p+a);
}
36 16 19
第九章 预处理
A部分(本、专科必做)
一、选择题
以下不正确的叙述是(D)
A、宏替换不占用运行时间。 B、宏名无类型。
C、宏替换只是字符替换。 D、宏名必须用大写字母表示。
C语言的编译系统对宏命令的处理(D)
A、在程序运行时进行的。 B、在程序连接时进行。
C、和C程序中的其它语句同时进行编译的。
D、在对源程序中其它语句正式编译之前进行的。
3、以下程序的输出结果是(C)。
A、15 B、100 C、10 D、150
#define MIN(x,y) (x)<(y)?(x):(y)
void main()
{
int I,j,k;
i=10;j=15;k=10*MIN(i,j);
printf(“%d\n”,k);
}
4、以下叙述中正确的是(D)
用#include包含的文件的后缀必须是“.h”。
若一些源程序中包含某个头文件;当该文件有错时,只需对该头文件进行修改,包含此头文件的所有源程序不必重新进行编译。
宏命令行可以看作是一行C语句。
预处理是在编译之前进行的。
5、以下叙述中正确的是(C)
A、源程序中所有的行都参加编译。
B、宏定义常量与const定义常量是一样的。
C、宏定义可以嵌套定义,即在宏定义中的字符串可以引用另一个宏定义的标识符。
D、以上都不正确。
二、填空题
以下程序中for 循环执行的次数是 6 。
#define N 2
#define M N+1
#define NUM (M+1)*M/2
void main()
{
int i;
for(i=1;i<=NUM;i++);
printf(“%d\n”,i);
}
2、以下程序的输出结果是 x=93 。
#define A 3
#define B(a) ((A+1)*a)
void main()
{
int x;
x=3*(A+B(7));
printf(“x=%d\n”,x);
}
B部分(本科必做)
编程:请写出一个宏定义MYALPHA(c),用以判断c是否是字母字符,若是,得1,否则,得0。
解:#define MYALPHA(c) ((c>=’A’&&c<=’Z’)||( c>=’a’&&c<=’z’)?1:0)
第十章 指针
A部分(本、专科必做)
一、选择题
1、若有定义:int x,*pb;则以下正确的表达式是(A)
A、pb=&x B、pb=x C、*pb=&x D、*pb=*x
2、以下程序的输出结果是(B)
A、因变量无定义输出不定值 B、0 C、-1 D、1
#include
void main()
{printf(“%d\n”,NULL);}
3、以下程序的输出结果是(B)
A、5,2,3 B、-5,-12,-7 C、-5,-12,-17 D、5,-2,-7
#include
void sub(int x,int y,int *z)
{*z=y-x;}
void main()
{
int a,b,c;
sub(10,5,&a); sub(7,a,&b); sub(a,b,&c);
printf(“%d,%d,%d\n”,a,b,c);
}
4、以下程序的输出结果是(C)
A、4 B、6 C、8 D、10
#include
void main()
{
int k=2,m=4,n=6;
int *pk=&k,*pm=&m,*p;
*(p=&n)=*pk*(*pm);
printf(“%d\n”,n);
}
5、已知指针p的指向(图一)的a[1],则执行语句*p++;后,*p的值是(B)。
A、20 B、30 C、21 D、31
a[0] a[1] a[2] a[3] a[4]
10
20
30
40
50
(图一)
6、已知指针p的指向(图一)的a[1],则表达式*++p的值是(B)。
A、20 B、30 C、21 D、31
7、已知指针p的指向(图一)的a[1],则表达式++*p的值是(C)。
A、20 B、30 C、21 D、31
8、以下程序的输出结果是(D)。
A、23 B、24 C、25 D、26
#include
void prtv(int *x)
{printf(“%d\n”,++*x);}
void main()
{
int a=25;prtv(&a);
}
9、以下程序的输出结果是(B)。
A、运行出错 B、100 C、a的地址 D、b的地址
#include
void main()
{
int **k,*a,b=100;
a=&b;k=&a;
printf(“%d\n”,**k);
}
10、以下程序运行后,输出结果是(D)。
A) 8 B) 7 C) 6 D) 5
#include
ss(char *s)
{ char *p=s;
while(*p) p++;
return(p-s);
}
main()
{ char *a="abded";
int i;
i=ss(a);
printf("%d\n",i);
}
二、填空题
1、若有定义:char ch;
(1)使指针p指向变量ch的定义语句是 char *p=&ch; 。
(2)若已定义char *p;,使指针p指向变量ch的赋值语句是 p=&ch; 。
(3)在(1)的基础上,通过指针p给变量ch读入字符的scanf调用语句是 scanf(“%c”,p); 。
(4)在(1)的基础上,通过指针p给变量ch赋字符’a’的语句是*p=’a’; 。
(5)在(1)的基础上,通过指针p用格式输出函数输出ch中字符的语句是printf(“%c”,*p); 。
2、以下程序输出的是 C 。
void main( )
{ int i=3, j=2;
char *a="DCBA";
printf("%c%c\n",a[i],a[j]);
}
3、以下函数的功能是,把两个整数指针所指的存储单元中的内容进行交换。请填空。
void exchange(int *x, int *y)
{ int t;
t=*y; *y= *x ; *x= t ;
}
B部分(本科必做)
程序填空:
1、下面程序的输出结果是 A B C D B C D C D D 。
char b[]="ABCD";
void main()
{ char *chp;
for(chp=b; *chp: chp+=2) printf("%s",chp);
printf("\n");
}
下面是一个字符串连接函数,请补充完整。
void mystrcat(char *s1,char *s2)
{
char *p,*q;
for(p=s1; *p ; p++ );
for( q=s2 ;*q;q++) *p++=*q ;
*p=’\0’ ;
}
第十一章 结构体与共用体
A部分(本、专科必做)
一、选择题
1、设有如下定义:
struct sk
{int a;float b;}data,*p;
若有p=&data;,则对data中的a域的正确引用是(B)。
A)(*p).data.a B)(*p).a C)p->data.a D)p.data.a
2、根据以下定义,能输出字母M的语句是(D)。
A、printf(“%c\n”,class[3].name); B、printf(“%c\n”,class[3].name[1]);
C、printf(“%c\n”,class[2].name[1]); D、printf(“%c\n”,class[2].name[0]);
struct person{char name[9];int age;};
struct person class[10]={“John”,17,”Paul”,19,”Mary”,18,”Adam”,16,};
3、以下程序的输出结果是(D)。
A、0 B、1 C、3 D、6
#include
void main()
{
struct emplx{int x;int y;}enum[2]={1,3,2,7};
printf(“%d\n”,enum[0].y/enum[0].x*enum[1].x);
}
4、若有以下说明及语句,则值为6的表达式是(D)。
A、p++->n B、p->n++ C、(*p).n++ D、++p->n
struct st{int n;struct st *next;};
struct st a[3],*p;
a[0].n=5;a[0].next=&a[1];a[1].n=7;a[1].next=&a[2];
a[2].n=9;a[2].next=’\0’;p=&a[0];
5、已知字符0的ASCII码的十进制的值是48,且数组的第0个元素在低位,以下程序的输出结果是(B)。
A、39 B、9 C、38 D、8
void main()
{
union{int i[2];long k;char c[4];}r,*s=&r;
s->i[0]=0x39;s->i[1]=0x38;
printf(“%x\n”,s->c[0]);
}
6、以下程序输出的结果是(C)。
A、32 B、16 C、8 D、24
typedef union{long x[2];int y[4];char z[8];}MYTYPE;
MYTYPE them;
void main()
{
printf(“%d\n”,sizeof(them));
}
7、设有以下语句
typedef struct S
{ int g; char h;} T;
则下面叙述中正确的是(B)。
A) 可用S定义结构体变量 B)可以用T定义结构体变量
C)S是struct类型的变量 D)T是struct S类型的变量
8、有以下说明和定义语句
struct student
{ int age; char num[8];};
struct student stu[3]={{20,"200401"},{21,"200402"},{10\9,"200403"}};
struct student *p=stu;
以下选项中引用结构体变量成员的表达式错误的是(D)。
A) (p++)->num B) p->num C) (*p).num D) stu[3].age
二、填空题
1、为了建立结构体(含有两个成员,data是数据成员,next是指向自身结构体的指针成员),请填空:
Struct link
{
char data;
struct link *next ;
}
2、把类型int另取一个类型名称INT,则以下应填:
typedef int INT;
3、以下程序的运行结果是2002Shangxian 。
# include
typedef struct student{
char name[10];
long sno;
float score;
}STU;
main( )
{
STU a={“zhangsan”,2001,95},b={“Shangxian”,2002,90},
c={“Anhua”,2003,95},d,*p=&d;
d=a;
if(strcmp(a.name,b.name)>0) d=b;
if(strcmp(c.name,d.name)>0) d=c;
printf(“%ld%s\n”,d.sno,p->name);
}
B部分(本科必做)
程序填空:
以下程序的功能是:处理由学号和成绩组成的学生记录,N名学生的数据已在主函数中放入结构体数组s中,它的功能是:把分数最高的学生数据放在b所指的数组中,注意:分数最高的学生可能不只一个,函数返回分数最高学生的人数。请填空。
#include
#define N 16
typedef struct
{
char num[10];
int s;
}STREC;
int fun(STREC *a,STREC *b)
{
int i,j=0,max=a[0].s;
for(i=0;i
if(max
for(i=0;i
if( a[i].s==max ) b[j++]=a[i];
return j;
}
void main()
{
STREC s[N]={{“GA005”,85},{“GA003”,76},{“GA002”,69},{“GA004”,85},
{“GA001”,91},{“GA007”,72},{“GA008”,64},{“GA006”,87},{“GA0015”,85},
{“GA0013”,91},{“GA0012”,64},{“GA0014”,91},{“GA0011”,66},{“GA0017”,64},
{“GA0018”,64},{“GA0016”,72},};
STREC h[N];
int i,n;
n=fun(s,h);
printf(“The %d highest score:\n”, n );
for(i=0;i
printf(“%s %4d\n”,h[i].num,h[i].s);
printf(“\n”);
}