




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、精选文档 C语言程序设计 实验报告专业 班级 日期 11月26日 成绩 实验组别 第 2(2.4) 次实验 指导教师 李开 学生姓名 学号 同组人姓名 实验名称 流程控制实验 一、实验目的(1)熟悉和掌握函数的定义、声明;函数调用与参数传递方法;以及函数返回值类型的定义和返回值使用。(2)熟悉和掌握不同存储类型变量的使用。(3)熟悉多文件编译技术。二、实验任务4.2 实验内容及要求1源程序改错下面是计算s=1!+2!+3!+n!的源程序,在这个源程序中存在若干语法和逻辑错误。要求在计算机上对这个例子程序进行调试修改,使之能够正确完成指定任务。#includevoid main(void) in
2、t k; for(k=1;k6;k+) printf(k=%dtthe sum is %ldn,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;2源程序修改替换(1)修改第1题中sum_fac函数,使其计算量最小。(2)修改第1题中sum_fac函数,计算。3跟踪调试计算fabonacci数列前n项和的程序如下:其中,long sum=0,*p=∑声明p为长整型指针并用&sum取出sum的地址对p初始化。*p表示引用p所指的变量(*p
3、即sum)。void main(void) int i,k; long sum=0,*p=∑ scanf(%d,&k); for(i=1;i=4 is the sum of two primes.10=3+712=5+720=3+175选做题假设一个C程序由file1.c、file2.c两个源文件和一个file.h头文件组成,file1.c、file2.c和file.h的内容分别如下,试编辑该多文件C程序,并编译和链接。然后运行生成的可执行文件。源文件file1.c的内容为:#include file.hint x,y; /* 外部变量的定义性说明 */char ch; /* 外部变量
4、的定义性说明 */void main(void) x=10; y=20; ch=getchar(); printf(in file1 x=%d,y=%d,ch is %cn,x,y,ch); func1();源文件file2.c的内容为:#include file.hvoid func1(void) x+; y+; ch+; printf(in file2 x=%d,y=%d,ch is %cn,x,y,ch);头文件file.h的内容为:#include extern int x,y; /* 外部变量的引用性说明 */extern char ch; /* 外部变量的引用性说明 */void
5、func1(void); /* func1函数原型 */4.3多源文件C程序的建立(结合第5题)三、实验步骤及结果(要求给出源程序和程序运行结果。另外,根据实验内容,记录编辑、编译、链接、调试程序的操作过程和实验现象)(2.4内容)1源程序改错下面是计算s=1!+2!+3!+n!的源程序,在这个源程序中存在若干语法和逻辑错误。要求在计算机上对这个例子程序进行调试修改,使之能够正确完成指定任务。#includevoid main(void) int k; for(k=1;k6;k+) printf(k=%dtthe sum is %ldn,k,sum_fac(k);long sum_fac(in
6、t n) long s=0; int i; long fac; for(i=1;i=n;i+) fac*=i; s+=fac; return s;(修改后)#includelong sum_fac(int n);int main(void) int k; for(k=1;k6;k+) printf(k=%dtthe sum is %ldn,k,sum_fac(k);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)修改第1题中sum_fac函数,
7、使其计算量最小。#includelongsum_fac(intn);intmain(void)intk;for(k=1;k6;k+)printf(k=%dtthesumis%ldn,k,sum_fac(k);return0;longsum_fac(intn)staticlongs=0;staticlongfac=1;fac*=n;s+=fac;returns; (2) 修改第1题中sum_fac函数,计算。#includefloat sum_fac(int n);int main(void) int k; for(k=1;k6;k+) printf(k=%dtthe sum is %fn,k,
8、sum_fac(k);float sum_fac(int n) float s=0; int i; long fac=1; for(i=1;i=n;i+) fac*=i;s+=1.0/fac; return s;3跟踪调试计算fabonacci数列前n项和的程序如下:其中,long sum=0,*p=∑声明p为长整型指针并用&sum取出sum的地址对p初始化。*p表示引用p所指的变量(*p即sum)。void main(void) int i,k; long sum=0,*p=∑ scanf(%d,&k); for(i=1;i=k;i+) sum+=fabonacci(i);
9、printf(i=%dtthe sum is %ldn,i,*p); long fabonacci(int n) if(n=1 | n=2) return 1; else return fabonacci(n-1)+fabonacci(n-2);单步执行程序,观察p,i,sum,n值。(1) 刚执行完scanf(%d,&k);语句,p,i值是多少?i=29p=5sum=0(2) 从fabonacci函数返回后光条停留在哪个语句上?printf(i=%dtthe sum is %ldn,i,*p);(3) 进入fabonacci函数,watch窗口显示的是什么?(4) 当i=3,从调用fabon
10、acci函数到返回,n值如何变化?n=3到n=2到n=1到n=34程序设计(1)编程让用户输入两个整数,计算两个数的最大公约数并且输出之(要求用递归函数实现求最大公约数)。同时以单步方式执行该程序,观察递归过程。#include#includeint Greatest_Common_divisor(int m,int n);int main(void) int m,n; printf(input two numbern); scanf(%d%d,&m,&n); Greatest_Common_divisor(m,n); return 0;int Greatest_Common_divisor(
11、int m,int n) int i; i=abs(m-n); if(i=m)|(i=n) printf(%d,i); else if(mn) Greatest_Common_divisor(n,i); else Greatest_Common_divisor(m,i); (2)编程验证歌德巴赫猜想:一个大于等于4的偶数都是两个素数之和。编写一个程序证明对于在符号常量BEGIN和END之间的偶数这一猜测成立。例如,如果BEGIN为10,END为20,程序的输出应为:GOLDBACHS CONJECTURE:Every even number n=4 is the sum of two prim
12、es.10=3+712=5+720=3+17#includeint isprime(int n) int j,x; for(j=2;j=4 is the sum of two primesn);for ( ;n = m;n+=2) for(i=2;i=(n/2);i+) if(isprime(i)!=0)&(isprime(n-i)!=0) printf(%d=%d+%dn,n,i,n-i); break; else continue; int main() int n,m; scanf(%d%d,&n,&m); as(n,m); return 0;5选做题假设一个C程序由file1.c、fi
13、le2.c两个源文件和一个file.h头文件组成,file1.c、file2.c和file.h的内容分别如下,试编辑该多文件C程序,并编译和链接。然后运行生成的可执行文件。源文件file1.c的内容为:#include file.hint x,y; /* 外部变量的定义性说明 */char ch; /* 外部变量的定义性说明 */void main(void) x=10; y=20; ch=getchar(); printf(in file1 x=%d,y=%d,ch is %cn,x,y,ch); func1();源文件file2.c的内容为:#include file.hvoid func
14、1(void) x+; y+; ch+; printf(in file2 x=%d,y=%d,ch is %cn,x,y,ch);头文件file.h的内容为:#include extern int x,y; /* 外部变量的引用性说明 */extern char ch; /* 外部变量的引用性说明 */void func1(void); /* func1函数原型 */#include extern int x,y; /* 外部变量的引用性说明 */extern char ch; /* 外部变量的引用性说明 */void func1(void); /* func1函数原型 */int x,y; /* 外部变量的定义性说明 */char ch;
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 企业人才建设管理办法
- 中试基地资金管理办法
- 住房保障考核管理办法
- 云南逗留人员管理办法
- 企业自备油罐管理办法
- 企业控制开支管理办法
- 信息广告制作管理办法
- 低保工作经费管理办法
- 人保寿险投诉管理办法
- 伊川疫情物资管理办法
- 装修设计文件消防专篇
- 八年级物理浮力压强专题经典计算题(含答案解析)
- GB/T 3211-2008金属铬
- GB/T 12703.7-2010纺织品静电性能的评定第7部分:动态静电压
- ps6000自动化系统用户操作及问题处理培训
- 2023年韶关市法院书记员招聘笔试模拟试题及答案解析
- 革兰氏阴性菌课件
- 聘用证书合集通用PPT模板
- 建筑工程文件归档管理明细表
- 海姆立克手法理论知识、临床应用及注意事项考核试题与答案
- 碱性脱漆剂配方
评论
0/150
提交评论