- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
C语言程序设计-第2次上机
C语言程序设计 实验报告
班级 CS1109 日期 2012,4,12
学生姓名 雷霞 学号 U201114439
第 2 次上机
实验1 函数与程序结构
(一) 实验目的
(1)熟悉和掌握函数的定义、声明;函数调用与参数传递方法;以及函数返回值类型的定义和返回值使用。
(2)熟悉和掌握不同存储类型变量的使用。
(3)熟悉多文件编译技术。
(二) 实验内容及要求
1.源程序改错
下面是计算s=1!+2!+3!+…+n!的源程序,在这个源程序中存在若干语法和逻辑错误。要求在计算机上对这个例子程序进行调试修改,使之能够正确完成指定任务。
源程序:
#includestdio.h
void main(void)
{
int k;
for(k=1;k6;k++)
printf(k=%d\tthe sum is %ld\n,k,sum_fac(k));
}
long sum_fac(int n)
{
long s=0;
int i;
long fac;
for(i=1;i=n;i++)
fac*=i;
s+=fac;
return s;
}
分析:(1)在调用某个函数时,一定要在main函数之前对该函数进行函数声明
(2)在函数long sum_fac()中,应对fac的初值进行定义,应令fac=1。
(3) for循环时,因为定义了s=0,所以必须把循环体用括号括起来,不然会出现以下情况。
编改的程序:
#includestdio.h
long sum_fac(int);
int main(void)
{
int k;
for(k=1;k6;k++)
printf(k=%d\tthe sum is %ld\n,k,sum_fac(k));
return;
}
long sum_fac(int n)
{
long s=0;
int i;
long fac=1;
for(i=1;i=n;i++){
fac*=i;
s+=fac;}
return s;
}
2.源程序修改替换
(1)修改上述源程序中的sum_fac函数,使其计算量最小。
分析:为使计算量最小,需要将s定义成静态局部变量,这样它就在第一次进入时执行一次赋初值操作,当退出块时,它的值就保存下来,以便再次进入块。但如果这时将循环体用括号括起来,就会出错。如图:
编写的程序:
#includestdio.h
long sum_fac(int);
int main(void)
{
int k;
for(k=1;k6;k++)
printf(k=%d\tthe sum is %ld\n,k,sum_fac(k));
return;
}
long sum_fac(int n)
{
static long s=0;
int i;
long fac=1;
for(i=1;i=n;i++)
fac*=i;
s+=fac;
return s;
}
(2)修改上述源程序中的sum_fac函数,计算
分析:(1)先要改变调用函数时要改变函数返回值的返回类型,由int改为float。
(2)同时printf里面的输出格式也应改为%lf,不然会出现输出结果为负值的情况。
(3)最后将等式改成“s+=(1/fac)”即可。
编写的程序如下:
#includestdio.h
float sum_fac(int);
int main(void)
{
int x;
printf(input an integer end of 0:\n);
scanf(%d,x);
printf(the sum is %lf\n,sum_fac(x));
return;
}
float sum_fac(int n)
{
float s=0;
int i;
float fac=1.0;
for(i=1;
文档评论(0)