文档库 最新最全的文档下载
当前位置:文档库 › C语言课后习题答案2014年新版(完整版)(1)

C语言课后习题答案2014年新版(完整版)(1)

C语言课后习题答案2014年新版(完整版)(1)
C语言课后习题答案2014年新版(完整版)(1)

习题答案

习题1(参考答案)

1.程序与算法的概念及二者的区别是什么?

程序:为了实现特定目标或解决特定问题而用计算机语言偏写的指令序列,它由算法和数据结构组成。

算法:(Algorithm)是在有限步骤内求解某一问题所使用的一组定义明确的规则。通俗地讲,就是计算机解题的步骤。

算法与程序的区别:计算机程序是算法的一个实例,同一个算法可以用不同的计算机语言来表达。

2.简述程序设计语言发展的过程

程序设计语言经过最初的机器代码到今天接近自然语言的表达,经过了四代的演变。一般认为机器语言是第一代,符号语言即汇编语言为第二代,面向过程的高级语言为第三代,面对象的编程语言为第四代。

3.简述高级程序设计语言中面向过程与面向对象的概念。

“面向过程”是一种以过程为中心的编程思想。首先分析出解决问题所需要的步骤,然后用函数把这些步骤一步一步地实现,使用的时候依次调用函数即可。一般的面向过程是从上往下步步求精,所以面向过程最重要的是模块化的思想方法。

“面向对象”是一种以事物为中心的编程思想。面向对象的方法主要是将事物对象化,对象包括属性与行为。

面向过程与面向对象的区别:在面向过程的程序设计中,程序员把精力放在计算机具体执行操作的过程上,编程关注的是如何使用函数去实现既定的功能;而在面向对象的程序设计中,技术人员将注意力集中在对象上,把对象看做程序运行时的基本成分。编程关注的是如何把相关的功能(包括函数和数据)有组织地捆绑到一个对象身上。

4.C语言程序的特点是什么?

(1)C语言非常紧凑、简洁,使用方便、灵活,有32个关键字,有9种流程控制语句。

(2)C语言运算符丰富,共有45个标准运算符,具有很强的表达式功能,同一功能表达式往往可以采用多种形式来实现。

(3)数据类型丰富。C语言的数据类型有整型、实型、字符型、数组类型、结构类型、共用类型和指针类型,而且还可以用它们来组成更复杂的数据结构,加之C语言提供了功能强大的控制结构,因而使用C语言能非常方便地进行结构化和模块化程序设计,适合于大型程序的编写、调试。

(4)用C语言可直接访问物理地址,能进行二进制位运算等操作,即可直接同机器硬件打交道。它具有“高级语言”和“低级语言”的双重特征,既能用于系统软件程序设计,又能用于通用软件程序设计。

(5)C语言生成的目标代码质量高、程序执行速度快。一般只比用汇编语言生成的目标代码的效率低20%左右。

(6)可移植性好。

5.源程序执行过程中,有哪些步骤?

C语言源程序的执行要经过:编辑、编译、链接、运行等步骤。

6.简述MATLAB的主要应用领域有哪些?

MATLAB软件是矩阵实验室(Matrix Laboratory)的简称,是美国MathWorks公司开发的商业数学软件,主要包括MA TLAB和Simulink两大部分。它和Mathematica、Maple并称为三大数学软件。MA TLAB软件可以进行矩阵运算、绘制函数和数据、实现算法、创建用户界面、连接其他编程语言的程序,主要应用于工程计算、控制设计、信号处理与通信、图像处理、信号检测、金融建模设计与分析等领域,代表了当今国际科学计算软件的先进水平。

1.计算的本质是什么?

计算的本质就是基于规则的符号串变换。

2.三大科学思维是指什么?

三大科学思维是:理论思维、实验思维与计算思维

3.什么是计算思维?计算思维的基本特征有哪些?

计算思维是指运用计算机科学的思想、方法和技术进行问题求解、系统设计、以及人类行为理解等涵盖计算机科学之广度的一系列思维活动。它属于三大科学思维(理论思维、实验思维与计算思维)之一,不仅仅属于计算机科学家,应当是每个人的基本技能,等同3R (Reading、wRiting、aRithmetic)。

从计算科学的角度来看,计算思维包括6个方面的特征:抽象性、数字化、构造性、系统化、虚拟化和网络化。

4.什么是算法?算法的基本特征有哪些?

算法:(Algorithm)是在有限步骤内求解某一问题所使用的一组定义明确的规则。通俗地讲,就是计算机解题的步骤。

算法的基本特征有:有穷性、确定性、可行性、有0个或多个输入、有一个或多个输出。

5.算法的复杂度分为哪两种?

算法的复杂度分为时间复杂度和空间复杂度两种。

6.什么是程序?程序与算法的区别是什么?

程序:为了实现特定目标或解决特定问题而用计算机语言偏写的指令序列,它由算法和数据结构组成。

算法:(Algorithm)是在有限步骤内求解某一问题所使用的一组定义明确的规则。通俗地讲,就是计算机解题的步骤。

算法与程序的区别:计算机程序是算法的一个实例,同一个算法可以用不同的计算机语言来表达。

7.简述程序设计语言发展的过程。

程序设计语言经过最初的机器代码到今天接近自然语言的表达,经过了四代的演变。一般认为机器语言是第一代,符号语言即汇编语言为第二代,面向过程的高级语言为第三代,

面对象的编程语言为第四代。

8.程序执行过程中,有哪些基本步骤?

C语言源程序的执行要经过:编辑、编译、链接、运行等步骤。

习题2(参考答案)

一、选择题

二、填空题

习题 3 (参考答案)

1.编程实现:用字符输入/输出函数输入3个字符,将它们反向输出。

参考代码(尽量运用本章所学知识)

#include

main( )

{ char c1,c2,c3;

c1=getchar(); c2=getchar(); c3=getchar();

putchar(c3); putchar(c2); putchar(c1);

}

2.编程实现:用格式输入/输出函数输入3个字符,将它们反向输出并输出它们的ASCII值。

参考代码(尽量运用本章所学知识)

#include

main( )

{ char c1,c2,c3;

scanf ("%c%c%c", &c1, &c2, &c3) ;

printf("%c %d,%c %d,%c %d ", c3,c3,c2,c2,c1,c1) ;

}

3.变量k为float 类型,调用函数:

scanf("%d", &k);

不能使变量k得到正确数值的原因是:

scanf("%d", &k);中的格式控制类型与变量k的定义类型不匹配,应将%d改为%f.

4. (略)

习题4答案

一选择题

1-20 DBDCA CBDDA ACABC BCBBC

二、写出下列程序的运行结果

1. z=36

2. 20 0

3. 12

4. 48,48

5. 13

6. 02

三编程题(参考答案)

1.输入4个整数a,b,c,d,编写程序,将它们按从大到小顺序输出。

#include

main()

{ int a,b,c,d,t;

scanf("%d%d%d%d",&a,&b,&c,&d);

if(a

if(a

if(a

if(b

if(b

if(c

printf("%4d%4d%4d%4d",a,b,c,d);

}

2.据所输入的3条边长值,判断它们能否构成三角形,如能构成,再判断是等腰三角形、直角三角形还是一般三角形?

源程序:

#include

#include "math.h"

main()

{float a,b,c,s,area;

scanf("%f%f%f",&a,&b,&c);

if((a+b>c)&&(a+c>b)&&(b+c>a)&&(fabs(a-b)

{

if(a==b&&b==c)

printf("等边三角形");

else if(a==b||b==c||a==c)

printf("等腰三角形");

else if((a*a+b*b==c*c)||(a*a+c*c==b*b)||(b*b+c*c==a*a))

printf("直角三角形");

else printf("一般三角形");

}

else printf("不能组成三角形");

}

3.输入一个整数,如果能被3,4,5同时整除,则输出“YES”,否则输出“NO”。

#include

main()

{ int t,flag;

scanf("%d",&t);

if(t%3==0&&t%4==0&&t%5==0)

printf("YES");

else

printf("NO");

}

4.输入年号,判断是否为闰年。判别闰年的条件是:能被4整除但不能被100整除,或者能被400整除。

#include

main()

{ int year;

printf("input the year:");

scanf("%d",&year);

if(year%4==0&&year%100!=0||year%400==0)

printf(" %d is leap year\n",year);

else

printf(" %d is't leap year\n",year);

}

5.编写程序。根据以下函数关系,对输入的每个x值进行计算,并输出相应的y值。

#include

main()

{ double x,y;

scanf("%lf",&x);

if(x>10) y=3*x+10;

else if(x>1) y=x*x+2*x;

else y=x*x-3*x+10;

printf(" %lf \n",y);

}

习题5答案

一、选择题

1-10 CDABC DABDC

11-20 DDDBD B(AC)CDC 17题有2个答案AC

二、写出下列程序的运行结果 1. 6420 2. 2 0

3. 5

4. ACEG

5. ###

6. 2,4,6,8,10

7. 46.0

8. 8 5 2

9. asDhEF

10. 12,72

三、编程题(参考答案) 1.利用近似公式...

7

1

51311+-+-

=4

π

求π的值,直到最后一项的绝对值小于10-6

为止。

#include

#include main()

{ double pi=0,i=1,j=1,k; do {

k=i/j; pi=pi+k; i=-i; j=j+2;

}while (fabs(k)>1.0e-6); printf("pi is %lf",4*pi); }

2.输入一行字符,分别统计出其中英文字母、数字、空格的个数。

#include main() { char t;

int n1=0,n2=0,n3=0; do

{scanf("%c",&t);

if(t=='\n')break; else

{if((t>='A'&&t<='Z')||(t>='a'&&t<='z')) n1++;

if(t==' ')n2++;

if(t>='0'&&t<='9') n3++;

}

}while(1);

printf("字符个数为:%d ,空格个数为:%d ,数字个数为:%d",n1,n2,n3);

}

3.从3个红球、5个白球、6个黑球中任意取出6个球,且其中必须有白球,编程输出所有

可能的组合。

#include

main()

{

int i,j,k;

printf("\n hong bai hei\n");

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

for(j=1;j<=5;j++)

{ k=6-i-j;

if(k>=0) printf(" %3d %3d %3d\n",i,j,k);

}

}

4.如果一个数等于其所有真因子(不包括该数本身)之和,则该数为完数。例如:6的真因子有1、2、3,且6=1+2+3,故6为完数。求[2,1000]内的:

(1)最大的完数;(2)完数数目。

#include

main()

{ int a,i,m,number=0,max=0;

for(a=1;a<=1000;a++)

{ m=0;

for(i=1;i<=a/2;i++)

if(a%i==0) m=m+i;

if(m==a) { number++, max=m;}

}

printf("number is %d, max is %d\n", number, max);

}

习题6答案

一、选择题

1.D 2.A 3.A 4.C 5.B 6.B 7.C

8.B 9.B 10.C 11.B 12.B 13.A 14.B

15.C 16.C 17.C 18.D 19.A 20.B 21.C

22.B 23.C 24.A 25.C 26.D 27.C 28.D

二、写出下列程序的运行结果

1.7 2.t=7531 3.1 3 6 4.8,17 5.5 6 6.8,8 7.3 6 9 12 8.10 9.39,18

10.64 54 11.-20 12.15 13.2 14.y=923

三、编程题(以下各题均用函数实现)

1.超级素数:一个素数依次从低位去掉一位、两位……若所得的数依然是素数,如239就是超级素数。试求100~9999之内:

(1)超级素数的个数;

(2)所有超级素数之和;

(3)最大的超级素数。

解:(1)spn=30(2)sps=75548(3)spm=7393

#include

#include

main()

{ int i,s=0,k=0,m,max=100;

for(i=9999;i>=100;i--)

{ m=i;

while(m>1)

if(fun(m))m=m/10;

else break;

if(m<=0)

{

if(max

k++;

s=s+i;

}

}

printf("超级素数的个数为:%5d,所有超级素数之和为:%5d,最大的超级素数为%5d\n",k,s,max);

}

int fun(int n)

{

int k,i;

k=sqrt(n);

for(i=2;i<=k;i++)

if(n%i==0)break;

if(i>=k+1)return 1;

else return 0;

}

2.其平方等于某两个整数平方和的正整数称为弦数,例如因52=32+42,故5是弦数,求(121,130)这间的弦数个数以及最大和最小的弦数。

解:n=4 max=130 min=122

参考程序1(用函数方法实现):

#include

main()

{

int k,maxnum,minnum;

k=count(121,130);

maxnum=max(121,130);

minnum=min(121,130);

printf("弦数的个数为:%d,最大的弦数为:%d,最小的弦数为:%d\n",k,maxnum,minnum);

}

int count(int m,int n)

{ int i,j,k,t=0,flag;

for(i=m;i<=n;i++)

{ flag=0;

for(j=1;j

for(k=j;k

if(i*i==j*j+k*k)

{

flag=1;

printf("%4d,%4d,%4d\n",j,k,i);//显示出不重复的弦数的组合情况

}

if(flag==1)t++;

}

return t;

}

int min(int m,int n)

{ int i,j,k,t=0;

for(i=m;i<=n;i++)

for(j=1;j

for(k=j;k

if(i*i==j*j+k*k)

{

printf("最小的弦数为:%4d\n",i);

return i;

}

}

int max(int m,int n)

{ int i,j,k,t=0;

for(i=n;i>=m;i--)

for(j=1;j

for(k=j;k

if(i*i==j*j+k*k)

{

printf("最大的弦数为:%4d\n",i);

return i;

}

}

3.有一个8层灯塔,每层所点灯数都等于该层上一层的两倍,一共有765盏灯,求塔底的灯数。

解:384

#include

main( )

{

int i,t;

t=fun(8);

for(i=1;i<8;i++)

t=t*2;

printf("t=%d\n",t);

}

int fun(int m)

{

int i,j,n=1,sum;

for(i=1;i<=765;i++)

{ sum=i;

n=i;

for(j=1;j

{ n=n*2;

sum=sum+n;

}

if(sum==765) break;

}

return i;

}

4.编写程序,求10

1!n

的结果。

解:4037913

参考程序1:

#include

main( )

{

int i;

long s=0;

for(i=1;i<=10;i++)

s=s+fun(i);

printf("s=%ld\n",s);

}

long fun(int n) {

int j; long t=1;

for(j=1;j<=n;j++) t=t*j; return t; }

参考程序2(递归算法): #include main( ) {

int i; long s=0;

for(i=1;i<=10;i++) s=s+fun(i); printf("s=%ld\n",s); }

long fun(int n) {

long t;

if(n==1)t=1;

else t=n*fun(n-1); return t; }

5.已知y =

(,)

( 2.3,)( 3.2,3)

f x n f x n f x n ++-+,其中,f (x , n ) = 1 - x 2 / 2! + x 4 / 4! - …

(-1)n x 2n / (2n )!(n ≥0),当x = 5.6,n = 7时,求y 的值。 解:0.007802

#include

double fun(double x,int n) {

int i,t=1,m=1;

double s=1.0,w=1.0; for(i=1;i<=2*n;i++) { w=w*x; t=t*i; if(i%2==0) { m=-m;s=s+m*w/t;} }

return s;

main()

{

double x=5.6;

int n=7;

double p,q,t,s;

p=fun(x,n);

q=fun(x+2.3,n);

t=fun(x-3.2,n+3);

s=p/(q+t);

printf("%lf\n",s);

}

6.编写程序,求三个数的最小公倍数。

#include

int fun(int x,int y,int z)

{ int j,t,m,n;

j=1;

t=j%x;

m=j%y;

n=j%z;

while(t!=0||m!=0||n!=0)

{ j=j+1;

t=j%x;

m=j%y;

n=j%z;

}

return j;

}

main()

{

int x1,x2,x3,j;

printf("Input x1 x2 x3: ");

scanf("%d%d%d",&x1,&x2,&x3);

printf("x1=%d,x2=%d,x3=%d\n",x1,x2,x3);

j=fun(x1,x2,x3);

printf("The minimal common multiple is: %d\n",j); }

7.已知:

()

()()

2

222

24

13352121

k

S

k k

=????

??-?+

,编写程序,求S的值。

例如,当k为10时,S的值应为:1.533852。#include

double fun(int k)

{

int n;

double s,w,p,q;

n=1;

s=1.0;

while(n<=k)

{ w=2.0*n;

p=w-1.0;

q=w+1.0;

s=s*w*w/p/q;

n++;

}

return s;

}

main()

{

printf("%f\n",fun(10));

}

习题7答案

一、选择题

1.C 2.A 3.C 4.B 5.D 6.C 7.D

8.C 9.A 10.B 11.C 12.D 13.D 14.C

15.C 16.D 17.D 18.D 19.B 20.B 21.B

22.C 23.A 24.A 25.A 26.D 27.D 28.D 29.C

二、写出下列程序的运行结果

1. 3 6 9 2.4

3.1,2,3,8,7,6,5,4,9,10, 4.7 0

5.572

三、程序填空

1. (1) k (2) -1

2. (1) i-1

3. (1) x[i++]或y[i++] (2)i++

4. (1) ‘a’+h-10 (2)s[i]= ’\0’

5. (1)s[i]!=’\0’(2)s[j++]=s[i]

6. (1)s[j]!=’\0’&& t[k]!=’\0’(2)t[k]==’\0’

四、编程题(每个程序的数据结构均用数组)

1.编写程序:从键盘上输入一个字符,用折半查找法找出该字符在已排序的字符串a中的位置。若该字符不在a中则输出**。

#include

main()

{

char c,a[10]="abcdefghi";

int top,bot,mid;

printf("input c:\n");

scanf("%c",&c);

printf("c=\'%c\'\n",c);

for(top=0,bot=10;top<=bot;)

{

mid=(top+bot)/2;

if(c==a[mid])

{

printf("The position is %d\n",mid+1);

break;

}

else if(c>a[mid]) top=mid+1;

else bot=mid-1;

}

if(top>bot) printf("**\n");

}

2.编写程序:输出某数列的前20项,该数列第1、2项分别为0和1,以后每个奇数编号的项是前两项之和,每个偶数编号的项是前两项之差的绝对值。生成的20个数存在一维数组x中,并按每行4项的形式输出。

#include

#include

main()

{

int x[21],i;

x[1]=0,x[2]=1;

i=3;

do

{

x[i]=x[i-2]+x[i-1];

x[i+1]=fabs((double)(x[i-1]-x[i]));

i=i+2;

}while(i<=20);

for(i=1;i<=20;i++)

{

printf("%6d",x[i]);

if(i%4==0) printf("\n");

}

}

3.编写程序:将s所指字符串中除了下标为奇数、同时ASCII值也为奇数的字符之外,其余的所有字符都删除,串中剩余字符所形成的一个新串放在t所指的数组中。

例如:若s所指字符串中的内容为:“ABCDEFG12345”,则最后t所指的数组中的内容应是:“135”。

#include

#include

void fun(char *s,char t[])

{

int i,j=0;

for(i=1;i

if(s[i]%2!=0)t[j++]=s[i];

t[j]='\0';

}

main()

{

char s[100],t[100];

printf("\nPlease enter string s:");

scanf("%s",s);

fun(s,t);

printf("\nThe result is:%s\n",t);

}

4.编写程序:一个自然数平方的末几位与该数相同时,称此数为自同构数。例如,因252=625,故25为自同构数。求出[1,700]之间的:①最大的自同构数;②自同构数数目。

(1)最大的自同构数:625 (2)自同构数数目:7个(1、5、6、25、76、376、625)

#include

main()

{

int i,n,ns,flag,count,r,rs;

static int a[50];

count=0;

for(i=1;i<700;i++)

{

n=i;

ns=i*i;flag=1;

while(n>0&&flag)

{

r=n%10;n=n/10;

rs=ns%10;ns=ns/10;

if(rs!=r) flag=0;

}

if(flag)

{

a[count]=i;count++;

printf("%5d",i);

}

}

printf("\ncount=%d,max=%d\n",count,a[count-1]);

}

5.已知:

f(0) = f(1) = 1

f(2) = 0

f(n) = f(n-1) - 2*f(n-2) + f(n-3) (n>2)

编写程序:求f(0)~f(50)中的最大值。

f(0)到f(50)中的最大值:598325

#include

main()

{

int n;

double f[181],max=0;

f[0]=f[1]=1;f[2]=0;

for(n=3;n<=50;n++)

{

f[n]=f[n-1]-2*f[n-2]+f[n-3];

if(max

}

printf("\n max=%.0lf",max);

}

6.编写程序:自然数1~1000按顺时针围成一圈,首先取出1,然后顺时针方向按步长L =50取数(已取出的数不再参加计数),直至所有的数均取完为止,最后一个取出的数是多少?

最后一个取出的数是:630

#include

main()

{

int a[1001],i,s=0,n=1;

for(i=1;i<=1000;i++) a[i]=i;

a[1]=0;

for(i=1;i<=1000;i++)

{

if(a[i]!=0)

{

s+=1;

if(s==50)

{

n++;

if(n==1000)

{

printf("\n a[%d]=%d",i,a[i]);

break;

}

a[i]=0;s=0;

}

}

if(i==1000) i=0;

}

}

7.编写程序:输出下列格式的杨辉三角形前5行。

1

1 1

1 2 1

1 3 3 1

1 4 6 4 1

#include

main()

{

int a[10][10],i,j,t,k;

printf("input lines <10:\n");

scanf("%d",&t);

for(i=0;i

{

for(j=0;j

{

printf(" ");

}

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

{

if((i==j)||(j==0)) a[i][j]=1;

else a[i][j]=a[i-1][j-1]+a[i-1][j];

printf("%6d",a[i][j]);

}

printf("\n");

}

}

8.若两素数之差为2,则称该两素数为双胞胎数。编写程序,求出[2,300]之内:(1)有多少对双胞胎数;

(2)最大的一对双胞胎数。

(1)最大的一对双胞胎数:281、283 (2)有19对双胞胎

#include

int sushu(int n)

{

int flag=1,i;

for(i=2;i<=n/2;i++)

if(n%i==0){flag=0;break;}

return(flag);

}

main()

{

int i,b,max1=0,max2=0,count=0;

for(i=2;i<300;i++)

{

if(sushu(i))

{

b=i+2;

if(sushu(b))

{

if(i>max1)

{max1=i;max2=b;}

count++;

}

}

}

printf("count=%d\nmax1=%4d,max2=%4d\n",count,max1,max2);

}

9.编写程序:将两个递增的数组a[10] = {2, 4, 6, 8, 10, 12, 14, 16, 18, 20}和b[10] = {1, 3, 5, 7, 9, 11, 13, 15, 17, 19}合并成一个数组c[20],并保持递增的顺序。

#include

#define N 10

#define NN 20

main()

{

int a[N]={2,4,6,8,10,12,14,16,18,20},b[N]={1,3,5,7,9,11,13,15,17,19},

c[NN];

int i,j,t,k;

i=0;j=0;t=0;

do

{

if(a[i]

{c[t]=a[i];i++;t++;}

else {c[t]=b[j];j++;t++;}

}while(i

10.请编写程序:建立一个N ×N 的矩阵(N <10)。矩阵元素的构成规律是:最外层元素的值全部为1;从外向内第2层元素的值全部为2;第3层元素的值全部为3,……依次类推。例如,当N = 5,生成的矩阵为:

11

1111222112321122211

1

1

1

1????????????????

#include

#define N 7

void fun(int (*a)[N]) { int i,j,k,m; if(N%2==0)m=N/2; else m=N/2+1; for(i=0;i

main() { int x[N][N]={0},i,j; fun(x); printf("\nThe result is:\n"); for(i=0;i

相关文档