C语言习题答案(6-7章)

更新时间:2023-10-04 19:54:01 阅读量: 综合文库 文档下载

说明:文章内容仅供预览,部分内容可能不全。下载后的文档,内容与下面显示的完全一致。下载之前请确认下面内容是否您想要的,是否完整无缺。

第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.编写程序,求?n!的结果。

110解:4037913 5.已知y =

f(x,n),其中,f(x, n) = 1 ? x2 / 2! + x4 / 4! ? ?(?1)nx2n / (2n)!

f(x?2.3,n)?f(x?3.2,n?3)(n≥0),当x = 5.6,n = 7时,求y的值。 解:-0.074521

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(\ x2 x3: \ scanf(\ printf(\ j=fun(x1,x2,x3); printf(\}

?2k?22427.已知:S?,编写程序,求S的值。 ????1?33?52k?1?2k?1????例如,当k为10时,S的值应为:1.533852。

#include #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(\}

2第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.abcdabcdabcdabcdbcdabcdabcdcdabcdd 2.4 3.1,2,3,8,7,6,5,4,9,10, 4.9,8

三、程序填空

1. (1) k (2) -1 2. (1) nose (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 main() { char c,a[10]=\ int top,bot,mid; printf(\ scanf(\ printf(\ for(top=0,bot=10;top<=bot;) { mid=(top+bot)/2; if(c==a[mid]) { printf(\ break; } else if(c>a[mid]) top=mid+1; else bot=mid-1; } if(top>bot) printf(\}

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(\ if(i%4==0) printf(\ } }

3.编写程序:将s所指字符串中除了下标为奇数、同时ASCII值也为奇数的字符之外,其余的所有字符都删除,串中剩余字符所形成的一个新串放在t所指的数组中。 例如:若s所指字符串中的内容为:“ABCDEFG12345”,则最后t所指的数组中的内容应是:“135”。

#include #include

void fun(char *s,char t[]) { int i,j=0; for(i=1;i

main() { char s[100],t[100]; printf(\ scanf(\ fun(s,t); printf(\} 4.编写程序:一个自然数平方的末几位与该数相同时,称此数为自同构数。例如,因252=625,

故25为自同构数。求出[1,700]之间的:① 最大的自同构数;② 自同构数数目。 #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;n=n/10; rs=ns;ns=ns/10; if(rs!=r) flag=0; } if(flag) { a[count]=i;count++; printf(\ } } printf(\ }

(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 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

本文来源:https://www.bwwdw.com/article/l98d.html

Top