C 语言程序设计 实验报告
专业 班级 日期 11 月 26 日 成绩
实验组别 第 2(2.4) 次实验 指导教师 李开
学生姓名 学号 同组人姓名
实验名称 流程控制实验
一、实验目的
(1)熟悉和掌握函数的定义、声明;函数调用与参数传递方法;以及函数返回值类型
的定义和返回值使用。
(2 )熟悉和掌握不同存储类型变量的使用。
(3)熟悉多文件编译技术。
二、实验任务
4.2 实验内容及要求
1.源程序改错
下面是计算 s=1!+2!+3!+ …+n! 的源程序,在这个源程序中存在若干语法和逻辑错误。
要求在计算机上对这个例子程序进行调试修改,使之能够正确完成指定任务。
#include
void main(void)
{
int k;
for(k=1;k<6;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;
}
2.源程序修改替换
(1)修改第 1 题中 sum_fac 函数,使其计算量最小。
1 1 1
s 1
(2 )修改第 1 题中 sum_fac 函数,计算 2! 3! n! 。
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);
printf("i=%d\tthe sum is %ld\n",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 值是多少?
(2 )从 fabonacci 函数返回后光条停留在哪个语句上?
(3)进入 fabonacci 函数, watch 窗口显示的是什么?
(4 )当 i=3 ,从调用 fabonacci 函数到返回, n 值如何变化?
4 .程序设计
(1)编程让用户输入两个整数,计算两个数的最大公约数并且输出之(要求用递归函数实
现求最大公约数) 。同时以单步方式执行该程序,观察递归过程。
(2 )编程验证歌德巴赫猜想:一个大于等于