大学生C语言程序设计(第四版 谭洪强)实验7 答案

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

实验七 参考答案(参考答案)

(1) (sy7-1.c )请编写函数fun ,它的功能是:计算并输出n (包括n )以内能被5 或9 整除的所有自然数的倒数之和。例如,若主函数从键盘给n 输入20后,则输出为s=0.583333。

注意:n 的值要求不大于100。

算法分析:

使用for 循环i ,遍历n 包含n 以内的所有整数,逐一判断每个i ,是否满足条件(能被5 或9 整除),如果满足,则把它的倒数累加到累加器里。注意:i 的倒数要表示成:1.0/i;

参考子函数如下:

double fun(int n)

{

double sum=0;

int i;

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

if(i%5==0||i%9==0)

sum=sum+1.0/i;

return sum;

}

(2) (sy7-2.c ) 请编写函数fun ,其功能是:根据以下公式计算s ,并计算结果作为函数值返回,n 通过形参传入。

n s ⋯++++⋯++++++=321132112111

例如:若n 的值为11时,函数的值为1.83333

算法分析:

等式右边从第二项(i=2)开始,其分母等于前一项的分母加上i ;一共有n 项;求出每项的分母,然后把每项进行累加。

参考子函数如下:

float fun(int n)

{

float sum=1; //sum 中已经累加了第一项的值

int i,m=1; //m 表示每项的分母;

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

{ m=m+i;

sum=sum+1.0/m;

}

return sum;

}

(3) (sy7-3.c)请编写函数fun,其功能是:将两个两位数的正整数a、b 合并形成一个整数放在c 中。合并的方式是:将 a 数的十位和个位依次放在c 数的十位和千位上,b 数的十位和个位数依次放在c 数的个位和百位上。

例如,当a=45,b=12,调用该函数后,c=5241。

算法分析:

对一个两位数n,它的各位可以通过n%10求的,它的十位数可以通过n/10求的;所以分别用上述方法求的a和b的个位和十位,同时按照要求累加到c里。

参考子函数如下:

long fun(int a, int b)

{

long c=0;

c=a%10*1000+a/10*10+b/10+b%10*100;

return c;

}

(4) (sy7-4.c)请编一个函数fun,函数的功能是使实型数保留2位小数,并对第三位进行四舍五入(规定实型数为正数)。例如:实型数为1234.567, 则函数返回1234.570000;实型数为1234.564, 则函数返回1234.560000。

算法分析:

先把这个数乘以100,然后再加0.5(实现四舍五入),再把这个数存放到一个长整型变量中,目的是把小数点后的小数去除,最后把这个数转换成浮点型数除以100,即可得出所的结果。

参考自定义函数如下:

float fun ( float h )

{ long w ;

w = h * 100 + 0.5 ;

return (float) w / 100 ;

}

(5) (sy7-5.c)请编写一个函数unsigned fun ( unsigned w ),w 是一个大于10的无符号整数,若w 是n (n ≥2)位的整数,函数求出w的低n-1位的数作为函数值返回。

例如:w 值为5923,则函数返回923;w 值为923 则函数返回23。

算法分析:

首先应求出w的位数,有一位,i就乘以10(如果有4位,i就等于10000);然后通过求模运算舍弃最高位;

参考子函数如下:

unsigned fun ( unsigned w )

{

int i=1;//i用来存放整数的位数

int j;

int n=w;

while(n)

{ n=n/10;

i=i*10;

}

i=i/10;

w=w%i;

return w; }

相关文档
最新文档