C语言习题答案1-10

合集下载
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

习题答案
习题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软件可以进行矩阵运算、绘制函数和数据、实现算法、创建用户界面、连接其他编程语言的程序,主要应用于工程计算、控制设计、信号处理与通信、图像处理、信号检测、金融建模设计与分析等领域,代表了当今国际科学计算软件的先进水平。

习题2(参考答案)
一、选择题
勘误:
3.以下定义语句中正确的是()。

A.int a=b=0 ; B.char A=65+1; b='b';
C.float a=1,*b=&a,*c=&b ; D.double a=0.0,b=1.1;
4.已知int x = 10,y = 3,表达式x/y的值是()。

15.在C语言中提供的合法的关键字是()。

A.swi t ch B.cher C.Case D.default
26.下列不可作为C语言赋值语句的是()。

A.x=3,y=5; B.a=b=6;C.i--; D.y=int(x);
40.下列变量定义中合法的是()。

A.float_a = 1-.1e-1; B.double b = 1 + 5e2.5;
C.long do = 0xfdaL; D.float 2_and = 1 - e - 3;
44.以下选项中不属于字符常量的是()。

A.'C' B."C" C.'\xCC0' D.'\072'
46题与17题重了
47题A项选择:a==1 后面加分号就合法了,所以只有“B”项合法
二、填空题
习题 3 (参考答案)
1.编程实现:用字符输入/输出函数输入3个字符,将它们反向输出。

参考代码(尽量运用本章所学知识)
#include <stdio.h>
main( )
{ char c1,c2,c3;
c1=getchar(); c2=getchar(); c3=getchar();
putchar(c3); putchar(c2); putchar(c1);
}
2.编程实现:用格式输入/输出函数输入3个字符,将它们反向输出并输出它们的ASCII值。

参考代码(尽量运用本章所学知识)
#include <stdio.h>
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答案
勘误:
6.若有以下定义:中B答案的switch((int)x)
选择题
1.B 2 .A 3 .B 4.B 5.C 6.B
阅读程序,写结果
7.12 8.13 9. *0**2*
10
if(s>=90)
m=4;
else if(s>=80)
m=3;
else if(s>=70)
m=2;
else if(s>=60)
m=1;
else
m=0;
11有4个整数a,b,c,d,编写程序按大小输出
#include<stdio.h>
main()
{ int a,b,c,d,t;
scanf("%d%d%d%d",&a,&b,&c,&d);
if(a<b) {t=a;a=b;b=t;}
if(a<c) {t=a;a=c;c=t;}
if(a<d) {t=a;a=d;d=t;}
if(b<c) {t=b;b=c;c=t;}
if(b<d) {t=b;b=d;d=t;}
if(c<d) {t=c;c=d;d=t;}
printf("%4d%4d%4d%4d",a,b,c,d);
}
12据所输入的3条边长值,判断它们能否构成三角形,如能构成,再判断是等腰三角形、直角三角形还是一般三角形。

源程序:
#include<stdio.h>
#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)<c)&&(fabs(a-c)<b)&&(fabs(b-c )<a))
{
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("不能组成三角形");
}
13 输入一个整数,如果能被3,4,5同时整除,则输出“YES”,否则输出“NO”。

#include<stdio.h>
main()
{ int t,flag;
scanf("%d",&t);
if(t%3==0&&t%4==0&&t%5==0)
printf("YES");
else
printf("NO");
}
14年号,判断是否为闰年。

判别闰年的条件是:能被4整除但不能被100整除的年是闰年,能被400整除的年也是闰年。

#include<stdio.h>
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);
}
15下面程序根据以下函数关系,对输入的每个x值,计算出y值。

请分析程序填空。

#include<stdio.h> 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.A 2 .A 3 .D 4.C 5. D 6.A 7 .D 8 .D 9.B 10 .C 阅读程序,写结果
11 .1 -2 12 .2 0 13 .*** 14 .2,4,6,8,10, 15 .46.000000 16 .852
17.利用公式...
7
151311+-+-
=4
π
公式求π。

#include<stdio.h>
#include<math.h> 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); }
18.求两个数的最大公约数和最小公倍数。

最大公约数:用大数整除小数,得到余数1; 再用小数整除余数1,得到余数2;再用余数1整除余数2,……直到余数为0。

最小公倍数:两数相乘再除以最大公约数。

#include<stdio.h>
#include<math.h>
main()
{ int m,n,r,x,y;
scanf("%d%d",&m,&n);
x=m;
y=n;
if (m<n) {r=m;m=n;n=r;}
while( (r=m%n)!=0)
{ m=n;
n=r;
}
printf(" the max common divisor is %d,the min common multiple is %d",n,x*y/n); }
19.从三个红球、五个白球、六个黑球中任意取出六个球,且其中必须有白球,编程输出所
有可能的组合。

#include<stdio.h>
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);
}
}
20.如果一个数等于其所有真因子(不包括该数本身)之和,则该数为完数。

例如:6的真
因子有1、2、3,且6=1+2+3,故6为完数。

求[2,1000]内的:
(1)最大的完数;(2)完数数目。

#include<stdio.h>
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.C 2.A 3.A 4.D 5.A 6.A 7.C
8.B 9.B 10.C 11.B 12.B 13.A 14.D
15.C 16.C 17.C 18.C 19.A 20.D 21.B
22.B 23.C 24.A 25.C 26.D 27.C 28.D
二、写出下列程序的运行结果
1.7 2.12 3.9 4.8,17 5.5 6
6.8,8 7.3 6 9 12 8.10 9.7
5
10.64 54 11.300 12.6 13.2
三、编程题(以下各题均用函数实现)
1.超级素数:一个素数依次从低位去掉一位、两位……若所得的数依然是素数,如239就是超级素数。

试求100~9999之内:
(1)超级素数的个数;
(2)所有超级素数之和;
(3)最大的超级素数。

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

解:n=4 max=130 min=122
3.有一个8层灯塔,每层所点灯数都等于该层上一层的两倍,一共有765盏灯,求塔底的灯数。

解:384
4.编写程序,求
10
1!n
∑的结果。

解:4037913
5.已知y =
(,)
( 2.3,)( 3.2,3)
f x n
f x n f x n
++-+
,其中,f(x, n) = 1 -x2 / 2! + x4 / 4!-…(-1)n x2n/ (2n)!
(n≥0),当x = 5.6,n = 7时,求y的值。

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

#include<stdio.h>
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<stdio.h>
#include<math.h>
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.D 5.D 6.C 7.A
8.A 9.A 10.B 11.A 12.D 13.D 14.C
15.C 16.D 17.D 18.D 19.B 20.A 21.B
22.B 23.B 24.C 25.D 26.D 27.D 28.D 29.C
二、写出下列程序的运行结果
1.abcdabcdabcdabcd bcdabcdabcd cdabcd d 2.4
3.1,2,3,8,7,6,5,4,9,10, 4.9,8
三、程序填空
1. (1) k (2) -1
2. (1) n%base (2)[d]
3. (1) x[i++]或y[i++] (2)i++
4. (1) ‘a’+h-10 (2)s[i]=(n<9)?n+’0’:’a’+n-10
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<stdio.h>
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<stdio.h>
#include<math.h>
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<stdio.h>
#include<string.h>
void fun(char *s,char t[])
{
int i,j=0;
for(i=1;i<strlen(s);i+=2)
if(i%2==1&&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]之间的:①最大的自同构数;②自同构数数目。

#include<stdio.h>
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]);
}
(1)最大的自同构数:625 (2)自同构数数目:7个(1、5、6、25、76、376、625)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)中的最大值。

#include<stdio.h>
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<f[n]) max=f[n];
}
printf("\n max=%.0lf",max);
}
f(0)到f(50)中的最大值:598325
6.编写程序:自然数1~1000按顺时针围成一圈,首先取出1,然后顺时针方向按步长L =50取数(已取出的数不再参加计数),直至所有的数均取完为止,最后一个取出的数是多少?
#include<stdio.h>
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;
}
}
最后一个取出的数是:630
7.编写程序:输出下列格式的杨辉三角形前5行。

1
1 1
1 2 1
1 3 3 1
1 4 6 4 1
#include<stdio.h>
main()
{
int a[10][10],i,j,t;
printf("input lines <10:\n");
scanf("%d",&t);
for(i=1;i<=t;i++)
{
for(j=1;j<=t-i;j++)
{
printf(" ");
}
for(j=1;j<=i;j++)
{
if((i==j)||(j==1)) 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)最大的一对双胞胎数。

#include<stdio.h>
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<299;i++)
{
if(sushu(i))
{
b=i+2;
if(sushu(b))
{
if(i>max1)
{max1=i;max2=b;}
count++;
}
}
}
printf("count=%d\nmax1=%4dmax2=%4d\n",count,max1,max2);
}
(1)最大的一对双胞胎数:281、283 (2)有19对双胞胎
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<stdio.h>
#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]<b[j])
{c[t]=a[i];i++;t++;}
else {c[t]=b[j];j++;t++;}
}while(i<N&&j<N);
if(i<N)
for(k=i;k<N;k++)
{c[t]=a[k];t++;}
if(j<N)
for(k=j;k<N;k++)
{c[t]=b[k];t++;}
{for(j=0;j<NN;j++)
printf("%4d",c[j]);
}
}
10.请编写程序:建立一个N ×N 的矩阵(N <10)。

矩阵元素的构成规律是:最外层元素的值全部为1;从外向内第2层元素的值全部为2;第3层元素的值全部为3,……依次类推。

例如,当N = 5,生成的矩阵为:
1111112221123211
22211
1111⎡⎤⎢⎥⎢⎥⎢⎥⎢⎥⎢⎥⎢⎥⎣⎦
#include<stdio.h>
#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<m;i++)
{
for(j=i;j<N-i;j++)
a[i][j]=a[N-i-1][j]=i+1;
for(k=i+1;k<N-i;k++)
a[k][i]=a[k][N-i-1]=i+1;
}
}
main()
{
int x[N][N]={0},i,j;
fun(x);
printf("\nThe result is:\n");
for(i=0;i<N;i++)
{for(j=0;j<N;j++)
printf("%3d",x[i][j]);
printf("\n");
}
}
习题8答案
一、选择题。

1.D
2.C
3.A
4.D
5.A
6.D
7.C
8.B
9.ABC10.C 11.D 12.A
二、写出下列程序的运行结果
1.
s=30;
t=-10;
m=200;
2.
2 2 2 2 1
3.
51
4.
abcdeedcba
5.
31
6.
1bc,a23
7.
50
三、填空题
1.在空格地方填上语句,以实现字符串复制的功能。

while(*p1!='\0')
{
*p2=*p1;
p1++;
p2++;
}
2.下面程序实现从键盘输入两个字符串a和b,再将a和b的对应位置字符中的较大者存放在数组c中,填空完成该程序。

while(*p&&*q)或while(*p!=’\0’&&*q!=’\0’)
{
if(*p>*q 或*p>=*q)c[k]=*p;
else c[k]=*q;
p++;
q++;
k++;
}
3.完成下面的程序,以实现单词的输出功能。

#include<stdio.h>
q=&s[k];
4.下列程序实现截取字符串s中从第m个位置开始的n个字符,返回所截字符串的首地址。

(程序中红色标注部分需改正)
#include<stdio.h>
static char sub[20];
main()
{ int m,n;
static char s[]="good morning";
char *cut(),*p;
scanf("%d%d",&m,&n);
p=cut(s,m,n);
printf("%s\n",p);
}
char *cut(char *s1,int m1,int n1)
{
int k;
for(k=0;k<n1;k++)
sub[k]= s1[m1-1+k];
sub[k]='\0';
return sub;
}
5.下列程序实现在N个元素的数组中查找最小的元素的功能。

return min;
min=minunm(a,N);
6.下列程序的功能为求数组元素的平均值。

avg=avg/n ;
avg=f( a ,10);
7.下列程序完成3个操作。

(1)输入10个字符串(每串不多于9个字符),依次放在a数组中,指针数组str中的每个元素依次指向每个字符串的开始。

(2)输入每个字符串。

(3)从这些字符串中选出最小的那个字符串并输出。

for(i=0;i<10;i++)
{ scanf("%s",sp);
str[i]= sp ;
k=strlen(sp);
sp+= k ;
}
k=0;
for(i=0;i<10;i++)
if(strcmp(str[i],str[k]) <0 )k=i;
printf(“%s\n”,str[k]) 或puts(str[k]) ;
8.以下程序利用指针法将两个数按从大到小的顺序显示。

int a,b, *p,*p1,*p2 ;
p1=&a ;
printf("max=%d,min=%d\n", *p1,*p2 );
9.下列程序把十进制数n转换成八进制数输出。

if( n<0 )
j= n%8 ;
printf("%c", *(s+i) );
10.下面程序把数组元素按相反的顺序进行存放。

for(i=x,j=x+n-1; i<j ;i++,j--)
inv(a,10) ;
11.用指针法求出数组中的最大元素与最小元素。

int max=array[0],min=array[0];
for( p=array ;p<array+n;p++)
p=number ;
12.把一个字符串按从小到大的顺序输出。

(红色标注部分需改正)
void sort(char *name[],int n)
for(j=i+1;j<=n;j++)
if( strcmp(name[k],name[j])>0 ) k=j;
printf("%s\n", name[i];
13.
av= s/N ;
y[ j++ ]=x[i]; x[i]=-1;}
if( x[i]!= -1 ) y[j++]=x[i];
四、编程题
1.(1)定义一个函数separate(int *data,int n),该函数将n的各个位上的数分离保存在data 所指向的数组中。

(2)定义一个函数judge(int *data,int len),判断data所指向的数组是否为回文。

(3)在main函数中调用上述函数,完成程序的功能。

参考代码:
#include "stdio.h"
#include "stdlib.h"
#define N 10
int separate(int *data,int n)
{
int i,k=0,temp;
while(n>0)
{
data[k]=n%10;
n=n/10;
k++;
}
for(i=0;i<=k/2;i++)
{
temp=data[i];
data[i]=data[k-1-i];
data[k-1-i]=temp;
}
return k;
}
int judge(int *data,int len)
{
int i,j;
i=0;j=len-1;
while(i<j)
{
if(data[i]==data[j])
{i++;j--;}
else
return 0;
}
return 1;
}
void main()
{
int data[N],n,len;
printf("请输入要转换的数n:\n");
scanf("%d",&n);
len=separate(data,n);
if(judge(data,len)==1)
printf("%d是回文数\n",n);
else
printf("%d不是回文数\n",n);
}
2.从键盘输入两个字符串,输出第一个字符串在第二个字符串中第一次出现的位置(即第一个字符串的首字母在第二个字符串中的位置,如“abc”在“bbacccabcddaw3”中的位置为7)。

要求:使用指针的方法遍历数组。

参考代码:
#include<stdio.h>
int find(char *s,char *t);
main()
{
int n;
char a[]="apbcdabfabcx";
char b[]="ab";
n=find(a,b);
if(n!=-1)
printf("%d\n",n);
else
printf("未找到!");
}
int find(char *s,char *t)
{
char *p,*q,*r;
int len,Loc=0;
while(*s)
{
p=s;r=t;
while(*r)
if(*p==*r)
{
p++;r++;
}
else
break;
if(*r=='\0') return Loc;
s++;Loc=Loc+1;
}
return -1;
}
3.有n个人围成一圈,顺序排号。

从第一个人开始报数(从1~3报数),报到3的人退出圈子,问最后留下的是原来第几号的人。

参考代码:
#include "stdio.h"
#define N 20 /*总人数*/
void main()
{
int i,a[N],num,dist;
num=0;
for(i=0;i<N;i++) a[i]=1;
i=0;dist=0;
while(num<N)
{
if(a[i]==1) dist++;
if(dist==3)
{ printf("%d\n",i);
a[i]=0;
dist=0;
num++;
}
i=(i+1)%N;
}
printf("最后留下的人是:%d号\n",i);
}
4.编写一个程序,实现两个顺序字符串(ASC码值由小到大)的连接,连接后的字符串仍为顺序串。

如字符串1为“aty”,字符串2为“eknx”,连接后的字符串为“aekntxy”。

参考代码:
#include "stdio.h"
void fun(char *s,char *t,char str[]) /*串s和t按ascii码顺序连接存入str中*/
{
int k=0;
while(*s&&*t)
{
if(*s<*t) str[k++]=*s++;
else str[k++]=*t++;
}
while(*s) str[k++]=*s++; /*把串s剩余字符存入str中*/
while(*t) str[k++]=*t++; /*把串t剩余字符存入str中*/
str[k]='\0';
}
void main()
{
char s[20],t[20],str[40];
printf("请输入字符串s和t\n");
scanf("%s%s",s,t);
fun(s,t,str);
printf("%s\n",str);
}
5.输入一行文字,找出其中大写字母、小写字母、空格、数字及其他字符各有多少?
参考代码:
#include "stdio.h"
void main()
{
char str[40],*p,n1=0,n2=0,n3=0,n4=0,n5=0;
gets(str);
p=str;
while(*p)
{
if(*p>='A'&&*p<='Z') n1++;
else if(*p>='a'&&*p<='z') n2++;
else if(*p>='0'&&*p<='9') n3++;
else if(*p==' ') n4++;
else n5++;
p++;
}
printf("大写字母:%d 小写字母:%d
数字:%d 空格:%d 其它:%d\n",n1,n2,n3,n4,n5);
}
6.输入一个字符串,内有数字和非数字字符,如:a123x456=4567?45at587,将其中连续的数字作为一个整数,依次存放到数组a中。

例如,123存放在a[0],456存放在a[1],…,统计共有多少个整数,并输出这些数。

参考代码:
#include "stdio.h"
#define N 10
void main()
{
char str[40],*p;
int k,a[N];
gets(str);
p=str;
k=0; /*k保存字符串中数的个数*/
for(;*p!='\0';p++)
if(*p>='0'&&*p<='9') /*计算连续的数字,遇到非数字结束计算,并将该数保存*/
{
a[k]=*p-'0';
p++;
while(*p>='0'&&*p<='9')
{
a[k]=a[k]*10+(*p-'0');
p++;
}
k++;
}
for(int i=0;i<k;i++)
printf("%d \n",a[i]);
}
习题9答案
一、选择题。

1.B
2.A
3.D
4.D
5.D
6.AD
7.A
8.D
9.B 10.A 11.D
二、填空题。

1.
p->name
p->score
p->name p->score
2.
p 或p!=NULL
c++
p=p->next
三、写出程序的运行结果。

1.
12,34
2.
2
4
3
9
12
12
11
11
18
9
3.
Zhao,m,85,90
4.
20
四、编程题
1.编写程序:input和output函数输入/输出5个学生的数据记录,其中每个学生包括学号(char num[6])、姓名(char name[8])、4门课程分数(score)信息。

参考代码:
#include "stdio.h"
#include "stdlib.h"
#define N 5
typedef struct
{
char num[6];
char name[8];
float score[4];
}STU;
void input(STU *s,int n)
{
int i,j;
printf("Please input %d students' num,name,score[4]:\n",n);
for(i=0;i<n;i++)
{
scanf("%s%s",s[i].num,s[i].name);
for(j=0;j<4;j++)
scanf("%f",&s[i].score[j]);
}
}
void output(STU *s,int n)
{
int i,j;
printf("Students' information:\n");
for(i=0;i<n;i++)
{
printf("%s %s ",s[i].num,s[i].name);
for(j=0;j<4;j++)
printf("%2.0f ",s[i].score[j]);
printf("\n");
}
}
void main( )
{
STU s[N];
input(s,N);
output(s,N);
}
2.现有如下一个结构体及变量,编程实现找到年龄最大的人,并输出。

static struct man
{ char name[20];
int age;
} person[4]={"li",18,"wang",19,"zhang",20,"sun",22};
参考代码:
#include "stdio.h"
#include "stdlib.h"
static struct man
{ char name[20];
int age;
} person[4]={"li",18,"wang",19,"zhang",20,"sun",22};
void main( )
{
int i,max_age,index;
max_age=person[0].age;
index=0;
for(i=1;i<4;i++)
if(person[i].age>max_age)
{
max_age=person[i].age;
index=i;
}
printf("The Oldest man is: %s,age:%d\n",person[index].name,person[index].age);
}
3.编写程序:有5个学生,每个学生有3门课的成绩,从键盘输入以上数据(包括学生号,姓名,3门课成绩),计算出平均成绩。

参考代码:
#include "stdio.h"
#include "stdlib.h"
#define N 5
typedef struct
{
char num[6];
char name[8];
float score[3];
}STU;
void input(STU *s,int n)
{
int i,j;
printf("Please input %d students' num,name,score[3]:\n",n);
for(i=0;i<n;i++)
{
scanf("%s%s",s[i].num,s[i].name);
for(j=0;j<3;j++)
scanf("%f",&s[i].score[j]);
}
}
void main()
{
STU s[N];
int i,j;float average[N];
input(s,N);
for(i=0;i<N;i++)
{
average[i]=0;
for(j=0;j<3;j++)
average[i]+=s[i].score[j];
average[i]/=3;
printf("第%d个同学的平均成绩为:%f\n",i,average[i]);
}
}
4.建立一个链表,每一个节点包括的成员为学生学号、平均成绩。

用malloc开辟新节点。

要求链表包括8个节点,从键盘输入节点的数据。

建立链表的函数名是create。

参考代码:
#include "stdio.h"
#include "stdlib.h"
#define N 8
typedef struct student
{
char num[5];
float score;
struct student *next;
}STU;
STU *create(int n)
{
int i;
STU *head,*p,*q;
head=p=(STU *)malloc(sizeof(STU));
for(i=0;i<n;i++)
{
printf("请输入第%d个学生的学号num及成绩score:\n",i+1);
q=(STU *)malloc(sizeof(STU));
scanf("%s%f",q->num,&q->score);
p->next=q;
p=q;
}
p->next=NULL;
return head;
}
void main()
{
STU *head,*p;
head=create(N);
p=head->next;
printf("Start->");
while(p)
{
printf("学号:%s 成绩:%2.0f->",p->num,p->score);
p=p->next ;
}
printf("End\n");
}
习题10答案
1.C
2.A
3.B
4.A
5.B。

相关文档
最新文档