函数与宏定义实验报告
实验项目:
姓名:杨佳琪 实验地点:524 实验时间:2021.5.18
一.实验目的与要求
<1>掌握函数的定义方法和调用规则;
<2>掌握在C语言程序中主调函数和被调用函数之间进行数据传递的规则;
<3>了解函数的返回值及其类型,并正确使用它;
<4>了解局部变量和全局变量的作用域及它们与存储分类的关系,理解变量的存在性和可见性的概念;
<5>练习递归函数的使用;
<6>理解宏的概念,掌握定义无参宏和带参宏的方法。了解文件包含的概念,掌握其用法;
<7>理解内部函数和外部函数,了解外部函数的编译和连接方法。
二.实验内容
1.实验练习:6.3.1实验2
1.1问题的简单描述:编写程序,求出从主调函数传来的数值i的阶乘值,然后将其传回主函数并输出。
1.2实验代码:
#define N 5
long function(int i)
{
static long f=1;
f=i*f;
return f;
}
int main()
{
long product;
int i;
for(i=1;i<=N;i++)
{
product=function(i);
printf("%d的阶乘是%d\n",i,product);
}
return 0;
}
2、实验练习:
#include <stdio.h>
int facsum(int m)
{
int sum=1,f=2;
while(f<=m/2)
{
if(m%f==0)
{
sum=sum+f;
f=f+1;
}
else
f=f+1;
}
return sum;
}
int main()
{
int m=3,n,k;
while(m<=500)
{
n=facsum(m);
k=facsum(n);
if(m==k&&m<=n)
{
printf("%d,%d\n",m,n);
m++;
}
else
m++;
}
}
3、实验练习:6.3实验4
3.1问题的简单描述:输入整数,输出高度为n的等边三角形。
3.2实验代码:
#include<stdio.h>
#include<math.h>
float area(float a,float b,float c )
{
float s,p,area;
s=(a+b+c)/2;
p=s*(s-a)*(s-b)*(s-c);
area=sqrt(p);
return(area);
}
main()
{
float a,b,c,ts;
printf("请输入三角形的三边:\n",a,b,c);
scanf("%f %f %f",&a,&b,&c);
ts=area(a,b,c);
if(a+b>c&&b+c>a&&a+c>b)
printf("area=%f\n",ts);
else
printf("Data error!");
}
4、实验6.5
实验代码:
#include<stdio.h>
int gcd(int a,int b)
{
int temp;
int remainder;
if(a<b)
{
temp=a;
a=b;
b=temp;
}
remainder=a%b;
while(remainder!=0)
{
a=b;
b=remainder;
remainder=a%b;
}
return b;
}
main()
{
int x,y;
int fac;
printf("请输入两个整数\n");
scanf("%d%d",&x,&y);
fac=gcd(x,y);
printf("The great common divisor is%d",fac);
}
问题分析:对新代码不太熟悉,需要对新代码有个熟悉的过程,细节处理不到位
三、辗转相除法
辗转相除法, 又名欧几里德算法,是求两个正整数之最大公约数的算法。它的具体做法是:用较大数除以较小数,再用出现的余数(第一余数)去除除数,再用出现的余数(第二余数)去除第一余数,如此反复,直到最后余数是0为止。如果是求两个数的最大公约数,那么最后的除数就是这两个数的最大公约数。 另一种求两数的最大公约数的方法是更相减损法。
四、实验小结
1.接触并逐渐学习辗转相除法的使用
2.对递归函数使用比原来熟悉
3.学着独立解决问题