《C语言程序设计》课后习题参考答案_第1页
《C语言程序设计》课后习题参考答案_第2页
《C语言程序设计》课后习题参考答案_第3页
《C语言程序设计》课后习题参考答案_第4页
免费预览已结束,剩余19页可下载查看

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、高等院校计算机基础教育规划教材C+程序设计课后习题参考答案 武汉大学出版社习题1参考答案一、 选择题1. A 2. D 二、 填空题1. BASIC、FORTRAN、AL_GOL60和COBOL2. 83. 关键字4. 编辑、编译、链接和运行三、 简答题1.答:(1)C语言具有结构化的控制语句。C语言提供了结构化程序所必需的基本控制语句,实现了对逻辑流的有效控制。(2)C语言具有丰富的数据结构类型。C语言除提供整型、实型、字符型等基本数据类型外,还提供了用基本数据类型构造出的各种复杂的数据结构,如数组、结构、联合等。C语言还提供了与地址密切相关的指针类型。此外,用户还可以根据需要自定义数据类型

2、。(3)C语言具有丰富的运算符。C语言提供了多达34种运算符,丰富的数据类型与丰富的运算符相结合,使C语言的表达力更具灵活性,同时也提高了执行效率。(4)C语言简洁、紧凑,使用方便、灵活,程序书写自由,有9种控制语句。(5)C语言既具有高级语言的功能,又具有低级语言的许多功能,通常被称为中级计算机语言。它既是成功的系统描述语言,又是通用的程序设计语言。(6)C语言与汇编语言相比,可移植性好。(7)功能强大。C语言具有低级语言的一些功能,所以,生成目标代码质量高,程序执行效率高。现在许多系统软件都用C语言来描述,可以大大提高了编程效率。2.答:运行一个C语言程序,一般需要经过如下几个步骤:上机输

3、入并编辑源程序;编译源程序;与库函数连接;生成可执行目标程序;运行目标程序。3.答:(1)操作系统的设计与实现。C语言是一种应用非常广泛的结构化高级程序设计语言,既适合编写应用软件,又适合编写系统软件。(2)工业控制。由于C语言具有简洁、灵活、代码效率高、能进行位操作等优点,C语言大量应用在单板机、单片机上,以及嵌入式领域等。(3)图形图像处理。C语言在内存管理和进程控制方面有丰富的指令,而且它能提供快速运行的代码,因而C语言适合进行图形程序设计。(4)教学领域。C语言是理想的结构化程序设计语言,其描述能力强,应用十分广泛,因此广泛应用于教学领域。许多计算机相关课程,如数据结构及算法大多是用C

4、语言进行描述的。习题2参考答案一、 选择题1. A 2.A 3.C二、 填空题1. 基本数据类型、构造数据类型、指针类型、空类型2. 反斜线“”3. 枚举数据类型(Enumerated Data Type)三、 简答题1.答:在语言中,数据类型可分为:基本数据类型、构造数据类型、指针类型、空类型四大类。基本类型是数据类型的基础,由它可以构造出其他复杂的数据类型。基本类型的值不可以再分解为其他类型。C语言的基本类型包括整型、实型(浮点型)、字符型和枚举型。C语言的构造类型包括数组类型、结构类型和联合类型。构造类型是根据已定义的一种或多种数据类型用构造的方法定义的。也就是说,一个构造类型的值可以分

5、解成若干个成员或元素。每个成员或元素都是一个基本数据类型,或又是一个构造类型。指针是一种特殊而又具重要作用的数据类型,其值表示某个量在内存中的地址。虽然指针变量的取值类似于整型量,但这是两种完全不同类型的量,一个是变量的数值,一个是变量在内存中存放的地址。在调用函数时,被调用函数通常应向调用函数返回一个函数值。返回的函数值具有一定的数据类型,应在函数定义的函数说明中给以说明。例如,在例1-1中给出的max函数定义中,函数头为int max(int a,int b,int c),其中写在函数名max之前的类型说明符int表示该函数的返回值为整型量。但是,也有一类函数,被调用后并不向调用函数返回函

6、数值,这种函数可以定义为空类型(也称无值型),其类型说明符为void。习题3参考答案一、 选择题1.C 2.B 3.B 4.D二、 填空题1. 4字节,1字节,4字节,8字节2. 203. 6 604. 26 255. 256 22三、 简答题1. C语言的基本类型包括整型、实型(浮点型)、字符型和枚举型。2. 定义符号常量和定义变量都要指定数据类型,系统将为其分配一定的存储空间。其不同之处在于:定义符号常量必须给出常量值,且以后不能修改本常量的值;而变量可以在定义变量的同时赋初值,以后可以修改该变量。3. 常量就是在程序的运行过程中该量是不可修改的量;变量在程序的运行过程中允许对该变量的值进

7、行修改。四、程序题1程序运行结果为:11101011-10-112程序运行结果为:3,12,4,4习题4参考答案一、 选择题1C 2D 3C 4C 5B 6D 7B 8C 9B二、 填空题1! & | 20 131445-1三、编程题1给出等级成绩A、B、C、D、E,假设,90分以上为A,8089分为B,7079分为C,6069分为D,60分以下为E,输入一个等级成绩,问属于哪一个分数段。参考代码如下:main() int score,m,n; char grade; n=1; while(n) printf(Please enter the score:); scanf(%d,&score)

8、; if(score100)|(score0)printf(n Wrong! n); else n=0; if(score=100) m=9; else m=(score-score%10)/10; switch(m) case 0:case 1:case 2:case 3:case 4:case 5:grade=E;break; case 6:grade=D;break; case 7:grade=C;break; case 8:grade=B;break; case 9:grade=A; printf(score=%d,grade=%cn,score,grade);2编程序打印出以下图形:

9、11211232112345678987654321参考代码如下:#includemain() int i,j; for(i=1;i=9;i+) for(j=1;j0;j-) printf(%d,j); printf(n); 3用1元5角钱人民币兑换5分、2分和1分的硬币(每一种都要有)共100枚,问共有几种兑换方案?每种方案各换多少枚?提示:设5分、2分和1分的硬币各换x,y,z枚,依题意有x+y+z=100,5x+2y+z=150,由于每一种硬币都要有,故5分硬币最多可换28枚,2分硬币最多可换73枚,1分硬币可换100-x-y枚,x,y,z只需满足第2个方程即可打印,对每一组满足条件的x

10、,y,z值,用计数器计数即可得到兑换方案的数目。参考代码如下:main() int x,y,z,s=0; for(x=1;x=28;x+) for(y=1;y=73;y+) for(z=1;z=148;z+) if(150=5*x+2*y+z) if(100=x+y+z) printf(x=%d y=%d z=%dn,x,y,z); s+; printf(s=%dn,s); 4编程:从键盘输入正整数n,输出1+(1+2)+(1+2+3)+(1+2+3+n)。参考代码如下:#include main() int n,i,s=0,t=0; printf(Please enter n=); scan

11、f(%d,&n); for(i=1;i=0;i-) scanf(%d,&ai); printf(Please enter x=n); scanf(%d,&x); p=aN; for(i=N;i0;i-) p=p*x+ai-1; printf(Pn(x)=%dn,p);2打印以下的杨辉三角形(要求打印6行)。11112113311464115101051参考代码如下:#include#include#define N 6main() int i,j,maxNN; for(i=0;iN;i+) for(j=0;jN;j+) maxi0=1; maxii=1; for(i=2;iN;i+) for(

12、j=1;ji;j+) maxij=maxi-1j-1+maxi-1j; for(i=0;iN;i+) for(j=0;j=i;j+) printf(%d,maxij); printf(n); 3编写程序,将一个数插入到有序的数列中去,插入后的数列仍然有序。参考代码如下:/*假设原有5个数*/#include main() int a6=1,2,6,10,15; int n,i,j; printf(Please enter the insert number:); scanf(%d,&n); for(i=0;iai) continue; else break; for(j=4;j=i;j-) a

13、j+1=aj; ai=n; for(i=0;i6;i+) printf(%d,ai); printf(n); 4编写程序,在有序的数列中查找某数,若该数在此数列中,则输出它所在的位置,否则输出no found。参考代码如下:#include main() int a10=1,2,3,4,5,6,7,8,9,10; int n,i,j,k=0; printf(Please enter the number:); scanf(%d,&n); for(i=0;i10;i+) while(n=ai)k=1;j=i;break; if(k=1) printf(a%dn,j); else printf(n

14、o found.n); 5编程将下列矩阵中的元素向右移动一列,最右一列移至第一列。1 4 6 8 10 12提示:用二维数组v存放矩阵中元素,数组v可在定义时初始化;有两种方法实现这种移动:一种方法是将移动后的元素放在另一个二维数组中;另一种方法是利用一个中间变量仍将移动后的元素放在数组v中。#includevoid main() int i,j; int a23=1,4,6,8,10,12; int b23; b00=a02; b01=a00; b02=a01; b10=a12; b11=a10; b12=a11; printf(a23:); for(i=0;i2;i+) printf(n)

15、; for(j=0;j3;j+) printf(%5d,aij); printf(nresult:n); for(i=0;i2;i+) printf(n); for(j=0;j3;j+) printf(%5d,bij); printf(n); getch();6利用公式计算mn的矩阵A和mn的矩阵B之和,已知为矩阵A的元素,为矩阵B的元素,为矩阵C的元素,。提示:用二维数组元素做函数参数编程实现矩阵相加。#include#include#define M 2#define N 2int aMN;int bMN;int cMN;void matrix(int aM,int bN);main()

16、int i,j,t; clrscr(); printf(Please input a%d%dn,M,N); for(i=0;iN;i+) for(j=0;jN;j+) scanf(%d,&t); aij=t; printf(Please input b%d%dn,M,N); for(i=0;iM;i+) for(j=0;jN;j+) scanf(%d,&t); bij=t; matrix(b,c); printf(a%d%d,M,N); for(i=0;iM;i+) printf(n); for(j=0;jN;j+) printf(%5d,aij); printf(n); printf(b%d

17、%d,M,N); for(i=0;iM;i+) printf(n); for(j=0;jN;j+) printf(%5d,bij); printf(n); printf(c%d%d=A+B:,M,N); for(i=0;iM;i+) printf(n); for(j=0;jN;j+) printf(%5d,cij); void matrix(int aM,int bN) int i,j,k,t; for(i=0;iM;i+) for(j=0;jN;j+) cij=aij+bij;习题6参考答案一、 选择题1A 2D 3D 二、 填空题1指针 取地址2339876 876424三、编程题1输入3

18、个整数,按从大到小的次序输出。参考代码如下:main() int a3,i,j,t; printf(Please enter three number:n) for(i=0;i3;i+) scanf(%d,&ai); for(i=0;i2;i+) for(j=0;j2;j+) if(ajaj+1) t=aj;aj=aj+1;aj+1=t; for(i=0;i3;i+) printf(%dn,ai);2编写将n阶正方矩阵进行转置的函数。在主函数中对一个4行4列的矩阵调用此函数。参考代码如下:int array44;convert(int array44) int i,j,t; for (i=0;

19、i4;i+) for (j=i+1;j4;j+) t=arrayij; arrayij=arrayji; arrayji=t; main( )int i,j;printf(Input array:n);for (i=0;i4;i+) for(j=0;j4;j+) scanf(%d,&arrayij);printf(noriginal array :n);for (i=0;i4;i+) for (j=0;j4;j+) printf(%5d,arrayij); printf(n);convert(array);printf(convert array:n);for (i=0;i4;i+) for(

20、j=0;j4;j+) printf(%5d,arrayij); printf(n); 3有三个整型变量i,j, k,请编写程序,设置三个指针变量p1,p2,p3,分别指向i, j,k。然后通过指针变量使i,j,k三个变量的值顺序交换,即把i的原值赋给j,把j的原值赋给k,把k的原值赋给i。要求输出i,j, k的原值和新值。参考代码如下:main() int i, j , k, temper; int *p1, *p2, *p3; printf(Please input 3 integers:n); scanf(%d%d%d,&i, &j, &k); p1=&i; p2=&j; p3=&k; p

21、rintf(before changed ,the 3 numbers are:n); printf(i=%d, j=%d,k=%dn,i, j, k); temper=*p1;*p1=*p3;*p3=*p2; *p2=temper; printf(after changed ,the 3 numbers are:n); printf(i=%d, j=%d,k=%dn,i, j, k);4用指针编写程序,把输入的字符串按逆顺序输出。参考代码如下:#include#includechar *s=1a2b3c4d;void main() int i,j; char t; for(i=0,j=str

22、len(s)-1;ij;+i,-j) t=si; si=sj; sj=t; printf(%sn,s);习题7参考答案一、 选择题1C 2B 3C二、填空题1float2自动(auto)31249.000000二、 编程题1.编写函数,已知三角形的三个边长,求三角形的面积。参考代码如下:#include#includemain() float a,b,c,s,area; printf(Please enter three sides:n); scanf(%f,%f,%f,&a,&b,&c); if(a+bc&b+ca&a+cb) s=(a+b+c)/2; area=sqrt(s*(s-a)*(

23、s-b)*(s-c); printf(area=%.2fn,area); else printf(It is not a triangle !n); 2.编程计算p=k! (m-k)!的值。参考代码如下:#includevoid main() int k,m; long p; printf(Please enter k,m:); scanf(%d,%d,&k,&m); p=f(k)*f(m-k); printf(%dn,p);int f(int n) if(n1) return n*f(n-1); else return 1;3.写一函数,使给定的一个二维数组(33)转置,即行列互换。并在主函

24、数中调用该函数时,使用数组作为实际参数。参考代码如下:#define N 3int arrayNN;convert(int arrayNN) int i,j,t; for (i=0;iN;i+) for (j=i+1;jN;j+) t=arrayij; arrayij=arrayji; arrayji=t; main()int i,j;printf(Input array(3*3):n);for (i=0;iN;i+) for(j=0;jN;j+) scanf(%d,&arrayij);printf(noriginal array:n);for (i=0;iN;i+) for (j=0;jN;

25、j+) printf(%5d,arrayij); printf(n);convert(array);printf(convert array:n);for (i=0;iN;i+) for(j=0;jN;j+) printf(%5d,arrayij); printf(n); 4.设计一个函数,用以计算下面数列前n项之和(以n为形参变量)。21、32、53、85、138、2113、。参考代码如下:#define N 6main() int n=N,i=1; float s=0; while (i=n) s=s+(i+1.0)/i; i+; printf(s(%d)=%.5fn,n,s);5.如果一

26、个数恰好等于它的因子之和,则该数称为“完数”。例如:6的因子是1、2、3,而6=1+2+3。编程序输出1000之内的所有完数。输出形式是:“6它的因子是1,2,3”。参考代码如下:main() static int k100; int i,j,n,s; for(j=2;j1000;j+) n=-1; s=j; for(i=1;ij;i+) if(j%i)=0) n+; s=s-i; kn=i; if(s=0) printf(%d is a wanshu,j); for(i=0;istudent.no=1001;20,1,2,100,101,1023结构体变量4Four, Three,Four三

27、、编程题1.有10个学生,每个学生的数据包括学号(num)、姓名(name9)、性别(sex)、年龄(age)、三门课成绩(score3),要求在main()函数中输入这10个学生的数据,并对每个学生调用函数count()计算总分。参考代码如下:#include#include#define N 2struct student int num;char name9;char sex;int age;int score3;stuN;main() int count(int s); int i,j; for(i=1;i=N;i+) printf(num:); scanf(%d,&stui.num)

28、; printf(name:); scanf(%s,&); printf(sex:); scanf(%s,&stui.sex); printf(age:); scanf(%d,&stui.age); for(j=0;j3;j+) printf(score%d:,j+1);scanf(%d,&stui.scorej); for(i=1;i=N;i+) printf(stu%d sum=%dn,i,count(stui.score); int count(int s) int i,sum=0; for(i=0;i3;i+) sum=sum+si; return sum; 2.口袋

29、中有若干红、黄、蓝、白、黑5种颜色的球,每次从口袋中取出3个球,编程打印出得到3种不同颜色的球的所有可能取法。参考代码如下:main() enum colorred,yellow,blue,white,black; enum color i,j,k,pri; int n=0,loop; for(i=red;i=black;i+) for(j=red;j=black;j+) if(i!=j) for(k=red;k=black;k+)if(k!=i) & (k!=j) n=n+1; printf(%-4d,n); for (loop=1;loop=3;loop+) switch (loop) c

30、ase 1:pri=i;break; case 2:pri=j;break; case 3:pri=k;break; default:break; switch (pri) case red: printf(%-10s,red);break; case yellow: printf(%-10s,yellow);break; case blue: printf(%-10s,blue);break; case white: printf(%-10s,white);break; case black: printf(%-10s,black);break; default:break; printf(

31、n); printf(ntotal:%5dn,n);3.25个人围成一个圈,从第1个人开始顺序报号,凡报号为3和3的倍数者退出圈子,找出最后留在圈子中的人原来的序号。参考代码如下:#includemain() int *a; int i,j,position=1,total=0,chage; a=(int *)malloc(25*sizeof(int); for (i=0;i25-total) position=position-25+total; chage=aposition-1; for (j=position;j25-total;j+) aj-1=aj; a25-total-1=cha

32、ge; total+; if (total=25) for (i=0;i,a25-i-1);printf(%dn,a0);printf(the last one is %dn,a0);return 0; 4.建立一个链表,每个结点包括:学号、姓名、成绩。(1)输入一个学号,检索该学生的有关信息;(2)从链表中删去成绩低于40分的学生。参考代码如下:#include#includestruct stu int no; char name9; int score; struct stu *next;struct stu *create() struct stu *head,*p,*q; int n

33、,s; head-next=NULL; p=head; while(1) printf(no,name,score:); scanf(%d,%s,%d,&n,&s); if(n=0&s=0) break; else q=(struct stu *)malloc(sizeof(struct stu); q-no=n;q-score=s;q-next=NULL; p-next=q;p=q; return head;struct stu *search(struct stu *h,int n) struct stu *p=h-next; while(p!=NULL&P-NO!=n) p=p-next

34、; return p;struct stu *delete(struct stu *head,char *s) struct stu *p1,*p2; if(head=NULL)printf(nempty list!n);goto end;p1=head;while (pi-score40 & p1-next!=NULL) p2=p1;p1=p1-next; free(p1); return head;main() int n; struct stu *q; printf(enter number:); scanf(%d,&n); q=create(n); printf(list:n); wh

35、ile(q!=NULL) printf(%sn,q-name); q=q-next; 习题9参考答案一、 选择题1D 2C 3A二、 填空题1L=18.849558 S=28.274337三、解答题预处理命令的功能是什么?包括哪几部分?#include预处理命令的两种格式分别为什么?答:预处理命令的功能是告诉编译系统在对源程序进行编译之前应该做些什么。预处理命令主要包括文件包含、宏定义和条件编译三个部分。#include预处理命令格式一:#include格式二:#include”包含文件名”习题10参考答案一、 选择题1C 2B 3A 二、 填空题1二进制文件2顺序 随机3hello,4pic

36、ursound三、编程题1.从键盘输入学生姓名,寻找学生记录是否存在,并输出相应信息。参考代码如下:#include#include#define N 10struct student char name9; int num; int age; char sex;stuN;void main() int i; char s10; FILE *fp; if(fp=fopen(stu,rb)=NULL) printf(Can not open file!n); exit(0); gets(s); for(i=0;iN;i+) fseek(fp,i*sizeof(struct student),0)

37、; fread(&stui,sizeof(struct student),1,fp); while(s=) printf(%s,%d,%d,%dn,,stui.num,stui.age,stui.sex); fclose(fp);2.有两个磁盘文件a和b,各存放一行字母。要求将两个文件的内容读到内存中,并将其合并到一起(按字母顺序排列),然后输出到一个新文件。参考代码如下:#include stdio.hmain() FILE *fp; int i,j,n; char c160,t,ch; if(fp=fopen(A,r)=NULL) printf(file A cannot be opened

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论