C语言输入Aa1Bb2Cc3,C语言全部章节复习题

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

{

printf("请输入第%d个数:",i+1);

scanf("%d",             );

}

max=array[0];

min=array[0];

for(i=0;i<=    ;i++)

{

if(maxif(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;jif(              )  k=j;

{ t=*(p+i); *(p+i)=*(p+k); *(p+k)=t; }

}

}

sort(a,7)  float* p,int n  *(p+k)

(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

}

}

float t;  *min=*p;  *maxB卷

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)

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;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
sm4加密算法是一种对称加密算法,其加密和解密使用相同的密钥。以下是使用C语言实现sm4加密算法的示例代码: ```c #include <stdio.h> #include <stdlib.h> #include <string.h> typedef unsigned char byte; typedef unsigned int word; #define GET_UINT32_BE(n,b,i) \ { \ (n) = ( (word) (b)[(i) ] << 24 ) \ | ( (word) (b)[(i) + 1] << 16 ) \ | ( (word) (b)[(i) + 2] << 8 ) \ | ( (word) (b)[(i) + 3] ); \ } #define PUT_UINT32_BE(n,b,i) \ { \ (b)[(i) ] = (byte) ( (n) >> 24 ); \ (b)[(i) + 1] = (byte) ( (n) >> 16 ); \ (b)[(i) + 2] = (byte) ( (n) >> 8 ); \ (b)[(i) + 3] = (byte) ( (n) ); \ } #define SBOX_TABLE_SIZE 256 #define SBOX_SIZE 16 #define SBOX_ROW_SIZE 4 #define SBOX_COL_SIZE 4 static const byte SboxTable[SBOX_TABLE_SIZE] = { /* 0 1 2 3 4 5 6 7 8 9 A B C D E F */ /*0*/ 0xd6,0x90,0xe9,0xfe,0xcc,0xe1,0x3d,0xb7,0x16,0xb6,0x14,0xc2,0x28,0xfb,0x2c,0x05, /*1*/ 0x2b,0x67,0x9a,0x76,0x2a,0xbe,0x04,0xc3,0xaa,0x44,0x13,0x26,0x49,0x86,0x06,0x99, /*2*/ 0x9c,0x42,0x50,0xf4,0x91,0xef,0x98,0x7a,0x33,0x54,0x0b,0x43,0xed,0xcf,0xac,0x62, /*3*/ 0xe4,0xb3,0x1c,0xa9,0xc9,0x08,0xe8,0x95,0x80,0xdf,0x94,0xfa,0x75,0x8f,0x3f,0xa6, /*4*/ 0x47,0x07,0xa7,0xfc,0xf3,0x73,0x17,0xba,0x83,0x59,0x3c,0x19,0xe6,0x85,0x4f,0xa8, /*5*/ 0x68,0x6b,0x81,0xb2,0x71,0x64,0xda,0x8b,0xf8,0xeb,0x0f,0x4b,0x70,0x56,0x9d,0x35, /*6*/ 0x1e,0x24,0x0e,0x5e,0x63,0x58,0xd1,0xa2,0x25,0x22,0x7c,0x3b,0x01,0x21,0x78,0x87, /*7*/ 0xd4,0x00,0x46,0x57,0x9f,0xd3,0x27,0x52,0x4c,0x36,0x02,0xe7,0xa0,0xc4,0xc8,0x9e, /*8*/ 0xea,0xbf,0x8a,0xd2,0x40,0xc7,0x38,0xb5,0xa3,0xf7,0xf2,0xce,0xf9,0x61,0x15,0xa1, /*9*/ 0xe0,0xae,0x5d,0xa4,0x9b,0x34,0x1a,0x55,0xad,0x93,0x32,0x30,0xf5,0x8c,0xb1,0xe3, /*A*/ 0x1d,0xf6,0xe2,0x2e,0x82,0x66,0xca,0x60,0xc0,0x29,0x23,0xab,0x0d,0x53,0x4e,0x6f, /*B*/ 0xd5,0xdb,0x37,0x45,0xde,0xfd,0x8e,0x2f,0x03,0xff,0x6a,0x72,0x6d,0x6c,0x5b,0x51, /*C*/ 0x8d,0x1b,0xaf,0x92,0xbb,0xdd,0xbc,0x7f,0x11,0xd9,0x5c,0x41,0x1f,0x10,0x5a,0xd8, /*D*/ 0x0a,0xc1,0x31,0x88,0xa5,0xcd,0x7b,0xbd,0x2d,0x74,0xd0,0x12,0xb8,0xe5,0xb4,0xb0, /*E*/ 0x89,0x69,0x97,0x4a,0x0c,0x96,0x77,0x7e,0x65,0xb9,0xf1,0x09,0xc5,0x6e,0xc6,0x84, /*F*/ 0x18,0xf0,0x7d,0xec,0x3a,0xdc,0x4d,0x20,0x79,0xee,0x5f,0x3e,0xd7,0xcb,0x39,0x48 }; static const word FK[4] = { 0xA3B1BAC6, 0x56AA3350, 0x677D9197, 0xB27022DC }; static const word CK[32] = { 0x00070e15, 0x1c232a31, 0x383f464d, 0x545b6269, 0x70777e85, 0x8c939aa1, 0xa8afb6bd, 0xc4cbd2d9, 0xe0e7eef5, 0xfc030a11, 0x181f262d, 0x343b4249, 0x50575e65, 0x6c737a81, 0x888f969d, 0xa4abb2b9, 0xc0c7ced5, 0xdce3eaf1, 0xf8ff060d, 0x141b2229, 0x30373e45, 0x4c535a61, 0x686f767d, 0x848b9299, 0xa0a7aeb5, 0xbcc3cad1, 0xd8dfe6ed, 0xf4fb0209, 0x10171e25, 0x2c333a41, 0x484f565d, 0x646b7279 }; #define ROTL(x,n) (((x) << (n)) | ((x) >> (32 - (n)))) #define L1(x) (x ^ ROTL(x, 2) ^ ROTL(x,10) ^ ROTL(x,18) ^ ROTL(x,24)) #define L2(x) (x ^ ROTL(x,13) ^ ROTL(x,23)) #define ROUND(x0,x1,x2,x3,x4,rk) \ { \ x4 = x1 ^ x2 ^ x3 ^ rk; \ x4 = L1(x4); \ x0 = x0 ^ x4; \ x4 = L2(x4); \ x1 = x1 ^ x4; \ x2 = x2 ^ x4; \ x3 = x3 ^ x4; \ } void sm4_setkey_enc(word SK[32], const byte key[16]) { word MK[4]; word k[36]; int i; GET_UINT32_BE(MK[0], key, 0); GET_UINT32_BE(MK[1], key, 4); GET_UINT32_BE(MK[2], key, 8); GET_UINT32_BE(MK[3], key, 12); k[0] = MK[0] ^ FK[0]; k[1] = MK[1] ^ FK[1]; k[2] = MK[2] ^ FK[2]; k[3] = MK[3] ^ FK[3]; for(i=0; i<32; i++) { ROUND(k[i], k[i+1], k[i+2], k[i+3], k[i+4], CK[i]); SK[i] = k[i+4]; } } void sm4_crypt_ecb(const word SK[32], int mode, int length, const byte input[], byte output[]) { word i; word ulbuf[36]; while(length > 0) { GET_UINT32_BE(ulbuf[0], input, 0); GET_UINT32_BE(ulbuf[1], input, 4); GET_UINT32_BE(ulbuf[2], input, 8); GET_UINT32_BE(ulbuf[3], input, 12); for(i=0; i<32; i++) { ROUND(ulbuf[0], ulbuf[1], ulbuf[2], ulbuf[3], ulbuf[4], SK[i]); } PUT_UINT32_BE(ulbuf[0], output, 0); PUT_UINT32_BE(ulbuf[1], output, 4); PUT_UINT32_BE(ulbuf[2], output, 8); PUT_UINT32_BE(ulbuf[3], output, 12); input += 16; output += 16; length -= 16; } } int main() { byte key[16] = {0x01, 0x23, 0x45, 0x67, 0x89, 0xab, 0xcd, 0xef, 0xfe, 0xdc, 0xba, 0x98, 0x76, 0x54, 0x32, 0x10}; byte input[16] = {0x01, 0x23, 0x45, 0x67, 0x89, 0xab, 0xcd, 0xef, 0xfe, 0xdc, 0xba, 0x98, 0x76, 0x54, 0x32, 0x10}; byte output[16]; word SK[32]; sm4_setkey_enc(SK, key); sm4_crypt_ecb(SK, 1, 16, input, output); printf("Input: "); for(int i=0; i<16; i++) { printf("%02x ", input[i]); } printf("\n"); printf("Output: "); for(int i=0; i<16; i++) { printf("%02x ", output[i]); } printf("\n"); return 0; } ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值