- 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语言程序设计-实第四次上机实验报告
5.第四次实验
C语言程序设计 实验报告
专业 计算机科学与技术 班级 信安1302班 日期 2014.4.26 成绩
实验组别 第 4 次实验 函数与程序结构实验编译预处理实验 指导教师
学生姓名 学号 同组人姓名
实验名称 函数与程序结构实验 编译预处理实验
4.1实验目的
1.熟悉和掌握函数的定义,声明,调用函数与参数传递的方法,以及函数返回值类型的定义和返回值使用.
2.熟悉和掌握不同存储类型变量的使用.
3.熟悉多文件编译技术.
4.掌握文件包含、宏定义、条件编译、assert宏的使用。
5.练习带参数的宏定义、条件编译的使用。
6.练习assert宏的使用。
7.使用集成开发环境中的调试功能:单步执行,设置断点,观察变量值。
4.2实验内容
(一)斐波那契数列F0=0,F1=1,Fn=Fn-1+Fn-2(n=2,nN*)shangji4\chengxu21
#include stdio.h
int F(int n);
int main()
{
int x;
do
{
printf(input a number:);
scanf(%d,x);
}while(x0);
printf(F%d=%d,x,F(x));
return 0;
}
int F(int n)
{
if(!n)
return (0);
else if(n==1) return (1);
else return(F(n-1)+F(n-2));
}
实验步骤:
步骤一:定义一个子函数求出斐波拉切数列第n项的值,子函数的形式参数为n控制项数,子函数中采用递归的思想求得结果。
步骤二:在主函数中通过键盘输入n的值,调用子函数将n的值传给形式参数,将计算得出的该项值返回到主函数,并在屏幕上输出。
调试及编译过程:
测试数据:1(第一项)
测试数据:2(第二项)
测试数据:7(任意选取一项)
不足及修改:
刚开始时未注意到项数有要求为大于或等于0,导致若输入的n值不在此区间内,则无法输出预期的结果。后改为控制一个循环,若输入的n值不符合要求,则重复提示输入和接受数据的过程。
结果:出现预期的实验结果。
(二)计算多项式的值anxn+ an-1xn-1+ an-2xn-2+…+a3x3+ a2x2+ a1x1+ a0
源程序如下:shangji4\chengxu22
#include stdio.h
int main()
{
int n,i,x,x1;
int a[800];
for(i=0;i800;i++)
a[i]=0;
printf(input a number:);
scanf(%d,n);
printf(input %d numbers:,n);
for(i=0;in;i++)
scanf(%d,a[i]);
printf(input x:);
scanf(%d,x);
if(n==1) printf(the final result is %d,a[0]);
else{
x1=x;
x=a[0]*x+a[1];
for(i=2;i=n-1;i++)
x=x*x1+a[i];
printf(the final result is %d,x);}
return 0;
}
实验步骤:
步骤一:在键盘端输入需要的项数,并定义一个数组用来存放各项系数,从左至右,按照计算的顺序,分别为最高项系数,依次往下,最后一项为常数项系数。
步骤二:将多项式采用拆分成多步乘积与相加的形式,通过控制循环改变与x相乘的因子,计算出最后结果并输出。
调试及编译过程:
测试数据:系数个数为1,即只有常熟项,此时分别输入两个不同的x的值如2和3,应得到的都是同一个值且为a的值。
测试数据:n=2,a0=2,a1=1,x=3(任意数据)
测试数据:n=3,a0=1,a1=2,a2=3,x=4(任意数据)
出现的不足及修改:最开始时当n为一时不能输出预期的结果,经分析得出是因为常数项系数的排列规律与其他项系数不一样,若按此排列方法,当n=1时,应作为另外一种情况讨论,直接输出a[0]即常数项的值即可。
实验结果:修改后可以输出预期的结
文档评论(0)