大学生C语言程序设计(第四版 谭洪强)实验7 答案
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 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; }