C语言期末考试题及答案(二)_假设变量a=2,b=3,t为整型变量,执行以下程序段后a和b的值分别为( )。 if a<b the-程序员宅基地

技术标签: C语言  

C语言(一)
一 选择题(7分,每小题0.5分)
1.C语言源程序的基本单位是( )。
A 过程 B 函数 C 子程序 D 标识符
2.下列程序的输出结果是( )。
main( )
{ int a=7,b=5;
printf("%d\n",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",’*’);
printf("\t");
}
main( )
{for(i=5;i<=8;i++)
prt( );
}
A *** B *** *** *** *** C *** *** D * * *
7.在C语言程序中,以下说法正确的是( )。
A函数的定义可以嵌套,但函数的调用不可以嵌套 B函数的定义不可以嵌套,但函数的调用可以嵌套 C函数的定义和函数的调用都不可以嵌套 D函数的定义和函数的调用都可以嵌套

8.以下函数调用语句中含有( )个实参。
func((e1,e2),(e3,e4,e5));
A 2 B 3 C 5 D 语法错误
9.以下程序的输出结果为( )。
#define ADD(x) x*x
main( )
{int a=4,b=6,c=7,d=ADD(a+b)*c;
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],*p=a;)( )。
A p=“abcd”; B a=“abcd”; C *p=“abcd”; D *a=“abcd”;
13.设有以下程序段,则值为6的表达式是( )。
struct st{ int n; struct st *next;};
static struct st a[3]={5,&a[1],7,&a[2],9,0 },*p;
p=&a[0];
A p+±>n B ++p->n C p->n++ D (*p).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\n”)的值是7。( )
6.通过return语句,函数可以带回一个或一个以上的返回值。( )
7.结构体类型只有一种。 ( )
8.char *p=“girl”;的含义是定义字符型指针变量p,p的值是字符串"girl"。( )
9.若有定义:char *p(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\n”,aver);
}
2.main( )
{char a[5]={‘A’,‘B’,‘C’,‘D’,‘E’},p=a,pa;
for(p=0;p<a+5;p++) printf(“%2c”,*p);
printf(“\n”);
printf(“%2c\n”,
(pa=&p));
}
3.main( )
{int a,b,s=0;
for(a=1,b=1;a<=100;a++)
{if(b>=20)
break;
if(b%31)
{b+=3;
continue;
}
b-=5;
}
printf(“a=%d\tb=%d\n”,a,b);
}
4.main()
{printf(“main( ) :%d\n”,fact(5));
fact(-5);
}
fact(int value)
{int f;
if(value<0)
{printf(“Arg error\n");
return(-1);
}
else if(value
1||value==0)
f=1;
else f=value
fact(value-1)+1;
printf(“This called value=%d\n”,f);
return f;
}
5.main( )
{int a=012,b=0x12,k=12;
char c=‘\102’,d=‘\r’;
printf(“a=%d\tb=%d\tk=%d\n”,a,b,k);
printf(“c=%c,d=%c%o\n”,c,d,a);
a=‘A’;
c=49;
printf(“a=%d\tc=%c\n”,a,c);
}
四 阅读下列程序,在 处填入适当内容,使程序完整(8分,每个空1分)
1.有一个3*4矩阵,求其中的最大元素。
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\n”,max_value(a));
}

2.输入x、y两个整数,按先大后小的顺序输出x、y。
#include “stdio.h”
main( )
{int x,y, *px,*py, (4) ;
scanf(“%d%d”,&x,&y);
(5) ;
(6) ;
if(x<y)
{p=px;
px=py;
py=p;
}
printf(“x=%d,y=%d\n”,x,y);
printf(“MAX=%d,MIN=%d\n”,*px,*py);
}
3.用选择排序法对任意10个整数按照由小到大排序。
main()
{int a[11],i,j,k,t;
printf(“Please input 10 numbers:\n”);
for(i=1;i<11;i++) scanf("%d",&a[i]);
printf("\n");
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:\n”);
for(i=1;i<11;i++)
printf("%d ",a[i]);
}
答案(一)
一 选择题(7分,每小题0.5分)

  1. B 2. C 3. B 4. B 5. C
  2. A 7. B 8. A 9. A 10. C
  3. A 12. A 13. B 14. D
    二 判断对错,对的划“√”,错的划“×”(5分,每小题0.5分)
    1.× 2.× 3.√ 4.√ 5.×
    6.× 7.× 8.× 9.√ 10.√
    四 阅读下列程序,在 处填入适当内容,使程序完整(8分,每个空1分)
    1.(1)int array[3][4](int array[][4])
    (2)return(max)
    (3)scanf(“%d”,&a[i][j])
    2.(4)*p
    (5)px=&x(py=&y)
    (6)py=&y(px=&x)
    3.(7)
    (8)

C语言(二)
一 选择题(24分,每小题2分)
1.已知函数fread的调用形式为fread(buffer,size,count,fp),其中buffer代表的是( )。
A 存放读入数据项的存储区 B 存放读入数据的地址或指向此地址的指针
C 一个指向所读文件的文件指针 D 一个整形变量,代表要读入的数据项总数
2.以下程序的输出结果为( )。
main( )
{int i=010,j=10;
printf("%d,%d\n",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,204.设i和k都是int类型,则for循环语句( )。
for(i=0,k=-1;k=1;i++,k++)
printf("****\n");
A 循环结束的条件不合法 B 循环体一次也不执行
C 循环体只执行一次 D 是无限循环
5.以下程序的输出结果为( )。
main( )
{char c;
int i;
for(i=65;i<68;i++)
{c=i+32;
switch
{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]!=’\0’)
i++;
while(s2[j]!=’\0’)
s1[i++]=s2[j++];
s1[i]=0;
printf("%s\n",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 (*ptr)();其中标识符ptr是( )。
A 是一个指向整形变量的指针 B 是一个指针,它指向一个函数值是int的函数
C 是一个函数名 D定义不合法
11.定义由n个指向整形数据的指针组成的数组p,其正确的方式为( )。
A int p; B int (*p)[n]; C int *p[n]; D int (*p)( );
12.具有相同类型的指针类型变量p与数组a,不能进行的操作是( )。
A p=a; B *p=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 *fp;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}},*p=s;
printf("%d",p++);
输出结果是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\n”,s);
}
2.main( )
{int x=31,y=2,s=0;
do
{s-=x
y;
x+=2;
y-=3;
}
while( x%3==0);
printf(“x=%d\ty=%d\ts=%d\n”,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(“\n”);
}
invert(int s[ ],int i,int j)
{int t;
if(i<j)
{invert(s,i+1j-1);
t=s[i];s[i]=s[j];s[j]=t;
}
}

4.#include<stdio.h> main()
{char str[ ]=“The C program”,c; int i;
for(i=2;(c=str[i])!=‘\0’;i++)
{switch
{case ‘g’: ++i;
break;
case ‘o’: continue;
default: printf(“%c”,c);
continue;
}
printf(“*”);
}
printf(“\n”);
}
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\n”,uw.word);
printf(“high byte:%02x\n”,uw.byte.high);
printf(“low byte:%02x\n”,uw.byte.low);
uw.byte.low=0x74;
printf(“word value:%04x\n”,uw.word);
result=uw.word+0x2a34;
printf(“the result:%04x\n”,result);
}
6.main()
{char *s2=“I love China!”,**s1=&s2;
char *s3,c,*s4=“w”;
s3=&c;
*s3=‘H’;
s2=s2+2;
printf(“%s\t%c\t%s\t%c\n”,s2,*s3,s4,**s1);
}
四 阅读下列程序,在 处填入适当内容,使程序完整(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+2* (3) 100)
    {n++;
    printf(“hb=%d,hm=%d,hl=%d\n”,hb/3,hm/2,2*hl); }
    }
    printf(“n=%d\n”,n);
    }
    2.用“起泡法”对输入的10个字符排序后按从小到大的次序输出。
    #define N 10
    char str[N];
    main()
    {int i,flag;
    for(flag=1;flag
    1;)
    {scanf("%s",str);
    flag=0;
    printf("\n");
    }
    sort(___(4)___);
    for(i=0;i<N;i++)
    printf("%c",str[i]);
    printf("\n");
    }
    sort(char str[N])
    {int i,j;
    char t;
    for(j=1;j<N;j++)
    for(i=0;(i<N-j)&&(str[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<m;i=i+m-1)
    for(j=0;j<n;j++)
    sum=sum+ (7)
    for(j=0;j<n;j=j+n-1)
    for(i=1; (8) i++)
    sum=sum+arr[i*n+j];
    return(sum);
    }
    4.用指针作函数参数,编程序求一维数组中的最大和最小的元素值。
    #define N 10
    main()
    {void maxmin(int arr[],int *pt1,int *pt2,int n);
    int array[N]={10,7,19,29,4,0,7,35,-16,21},*p1,*p2,a,b;
    p1=&a;
    p2=&b;
    maxmin(array,p1,p2,N);
    printf(“max=%d,min=%d”,a,b);
    }
    void maxmin(int arr[],int *pt1,int *pt2,int n)
    {int i;
    *pt1=*pt2=arr[0];
    for(i=1;i<n;i++)
    {if(arr[i]>*pt1)
    (9)
    if(arr[i]<*pt2)
    (10)
    }
    }

答案(二)
一 选择题(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 pr*am
  5. word value:1234
  6. love China! H w l
    high byte:12
    low byte:34
    word value:1274
    the result:3ca8
    四 阅读下列程序,在 处填入适当内容,使程序完整(20分,每个空2分)
  7. (1) 3 (2) 2 (3)hm hl
  8. (4) str (5) str[i]=str[i+1] (6) str[i+1]=t
  9. (7) arr[in+j](或者arr[i10+j])
    (8) i<m-1(或者i<=m-2)
  10. (9) *ptr1=arr[i] (10) *ptr2=arr[i]
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/MrLuo8/article/details/108898127

智能推荐

数据库Mysql+SSM技术开发,SSM 泰州市二手房交易平台系统--03401(上万套实战教程手把手教学,免费领取源码)-程序员宅基地

文章浏览阅读162次。关注●点赞收藏并私信博主,免费领取项目源码哦~总体设计主要包括系统总体结构设计、系统数据结构设计、系统功能设计和系统安全设计等;详细设计主要包括模块实现的关键代码,系统数据库访问和主要功能模块的具体实现等。最后对系统进行功能测试,并对测试结果进行分析总结,及时改进系统中存在的不足,为以后的系统维护提供了方便,也为今后开发类似系统提供了借鉴和帮助。

【部署网站】使用nginx+tomcat部署博客网站_用nignx发布网站和用tomcat部署-程序员宅基地

文章浏览阅读3.1k次,点赞3次,收藏16次。一、什么是静态网站、动态网站?静态网站没有采用任何程序开发,是纯粹使用html语言写出的网站,网页文件名以html或htm结尾。原则上不会受到攻击入侵,但是也无法在网络上实时更新内容,就纯粹的是制作好的页面。动态网站目前的主要开发语言有ASP,JSP,PHP,ASP.NET在制作好之后,都有一个网站管理后台,当以管理员身份登陆时,可以对网站的内容进行增删操作,直接在网上进行这些操作,虽然它可以随时更新,但是速度较慢。并且需要区分的是,动态网站的动态指的是动态实时更新而非网站有动态画面。区分静态网站和动_用nignx发布网站和用tomcat部署

android 实现定时任务,Android 实现定时任务的五种方式的讲解-程序员宅基地

文章浏览阅读3.9k次。1、普通线程sleep的方式,可用于一般的轮询Pollingnew Thread(new Runnable() { @Override public void run() { while (true) { //todo ..._android 定时20个小时

Dr_can模型预测控制笔记与代码实现-程序员宅基地

文章浏览阅读2.7w次,点赞206次,收藏552次。因而我们引入模型预测控制(Model PredictiveControl)的概念,对于一般的离散化系统(因为实际计算机实现的控制系统都是离散的系统,连续系统离散化的方法在此不述)。在k时刻,我们可以测量或估计出系统的当前状态y(k),再通过计算得到的u(k),u(k+1),u(k+2)...u(k+j)得到系统未来状态的估计值y(k+1),y(k+2)...y(k+j);我们将预测估计的部分称为预测区间(Predictive Horizon),将控制估计的部分称为控制区间(Control Horizon)_dr_can

由浅入深!小程序FMP优化实录,已拿offer入职_小程序fmp是指的什么(1)-程序员宅基地

文章浏览阅读569次,点赞25次,收藏12次。其实很简单就下面这张图,含概了Android所有需要学的知识点,一共8大板块:架构师筑基必备技能Android框架体系架构(高级UI+FrameWork源码)360°Androidapp全方位性能调优设计思想解读开源框架NDK模块开发移动架构师专题项目实战环节移动架构师不可不学习微信小程序混合开发的flutterAndroid学习的资料我呢,把上面八大板块的分支都系统的做了一份学习系统的资料和视频,大概就下面这些,我就不全部写出来了,不然太长了影响大家的阅读。

计算带余除法(四种方法)_带余除法怎么写编程-程序员宅基地

文章浏览阅读387次,点赞12次,收藏4次。给定两个整数a和b (0 < a,b < 10,000),计算a除以b的整数商和余数。一行,包括两个整数a和b,依次为被除数和除数(不为零),中间用空格隔开。一行,包含两个整数,依次为整数商和余数,中间用一个空格隔开。示例:输入:15 2,输出:7 1_带余除法怎么写编程

随便推点

数字化转型背景下的金融交易业务中台实践-程序员宅基地

文章浏览阅读140次。引言:目前金融业IT系统大多由业务部门或渠道进行竖井式建设,这种模式的好处是系统专业性强,但同时也给运营及IT管理部门带来分散性阵痛。那么如何在强监管与统一风控的形势下,实现统一管控、快速响应、应需而变、按期交付?中台架构就是在这种背景下应运而生。本文主要以某城商行基于BIIP实施的交易中台的实践案例展开分享,一起和大家探讨企业数字化转型中的背景、技术..._运营转型 业务中台

AWG标准_awg官方规范-程序员宅基地

文章浏览阅读1.5k次。AWG 直径 面积 铜阻抗 (inch) (mm) (kcmil) (mm²) (Ω/km) (Ω/kFT) 0000 (4/0) 0.46 11.684 212 107 0.1608 0.04901 000 (3/0) 0.4096 10.404 168 85 0.202..._awg官方规范

图像修复论文Residual Non-local Attention Networks for Image Restoration阅读笔记-程序员宅基地

文章浏览阅读2.8k次。论文来源:ICLR2019论文链接:pdf (openreview.net)_residual non-local attention networks for image restoration

表达式计算。问题描述:编写程序,计算并输出如下表达式的值:y=其中a,x,y均为float类型,取值为3.1415926。输出结果要求保留小数点后3位。_serialprintln(a)的结果为-程序员宅基地

文章浏览阅读153次。【代码】表达式计算。问题描述:编写程序,计算并输出如下表达式的值:y=其中a,x,y均为float类型,取值为3.1415926。输出结果要求保留小数点后3位。_serialprintln(a)的结果为

android 自定义Toast 吐司-程序员宅基地

文章浏览阅读274次,点赞3次,收藏8次。【Android 详细知识点思维脑图(技能树)】其实Android开发的知识点就那么多,面试问来问去还是那么点东西。所以面试没有其他的诀窍,只看你对这些知识点准备的充分程度。so,出去面试时先看看自己复习到了哪个阶段就好。虽然 Android 没有前几年火热了,已经过去了会四大组件就能找到高薪职位的时代了。这只能说明 Android 中级以下的岗位饱和了,现在高级工程师还是比较缺少的,很多高级职位给的薪资真的特别高(钱多也不一定能找到合适的),所以努力让自己成为高级工程师才是最重要的。

FP-Growth算法之FP-tree的构造(python)_利用fpgrowth算法对其构造一个fptree,树的最大高度-程序员宅基地

文章浏览阅读7.4k次。前言:关于 FP-Growth 算法介绍请见:FP-Growth算法的介绍。 本文主要介绍 FP-tree 的构造算法,关于伪代码请查看上面的文章。上接:FP-Growth算法python实现;下接:FP-Growth算法之频繁项集的挖掘(python)。 正文:tree_builder.py\color{aqua}{tree\_builder.py}文件:#coding=utf-8import_利用fpgrowth算法对其构造一个fptree,树的最大高度