第四次实验报告

C语言程序设计实验报告

实验项目:函数与宏定义

姓名:丁哲航  实验时间:2021.5.27  实验地点:一教524

一、实验目的与要求

1、掌握函数的调用方法和定义规则;
2、掌握在C语言程序中主调函数与被调函数之间数据传递的规则;
3、了解函数的返回值与类型,并将其正确使用;
4、了解局部变量与全局变量的作用域与它们与储存分类的关系,理解变量的存在性和可见性的概念;
5、熟悉练习递归函数的使用;
6、理解宏的概念,掌握定义无参宏和有参宏的方法;
7、理解文件的概念,并掌握其用法;
8、理解内部函数和外部函数,掌握外部函数的编译方法和连接方法;

二、实验内容

1.实验6.3

实验代码:

#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!");
}


问题分析:注意在if中输入三角型三边的关系,开始没有用scanf,导致运行时没有输入,运行后改正。

2.实验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);
}


问题分析:注意temp的用法,把temp当作一个空位子,当两个数需要互换时需要用到这个空位子来将两者调换,第一次运行时就因为没有正确使用temp而出现错误结果,且在while(remainder!=0)中需要再输入一次remainder=a%b,否则输入时无论输入何值都会进入循环。

3.实验6.6

实验代码:

#include<stdio.h>
void trangle(int n)
{
	int i,j;
	for(i=0;i<n;i++)
	{
        for(j=0;j<n-i;j++)
        {
    	printf(" ");
	}
	for(j=0;j<=2*i;j++)
	{
		printf("*");
	}
	putchar('\n');
	
	}
}
void main()
{
	int n;
	int fac;
	printf("请输入一个整数n\n");
	scanf("%d",&n);
	printf("\n");
	trangle(n);
}


问题分析:本实验需要注意3个for循环的嵌套使用,且变量需从0开始,从一开始的变量会多一个空格,进而少一个数。

4.实验6.7

实验代码:

#include<stdio.h>
int facsum(int m)
{
	int sum=1,f=2;
	while(f<=m/2)
	{
	if(m%f==0)
	{
	   sum=sum+f;
	   f++;
	}
	else
	f=f+1;
	} 
	return sum; 
}
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++;
	}
}


问题分析:首先需要正确理解题目的意思,根据题意编辑代码,开始没有看懂,编辑时花费时间较长,编辑代码首先定义函数facsum(m),返回给正整数m的所有因子,然后调用函数facsum()完成代码编辑。

三、辗转相除法

辗转相除法, 又名欧几里德算法,是求两个正整数之最大公约数的算法。它的具体做法是:用较大数除以较小数,再用出现的余数(第一余数)去除除数,再用出现的余数(第二余数)去除第一余数,如此反复,直到最后余数是0为止。如果是求两个数的最大公约数,那么最后的除数就是这两个数的最大公约数。 另一种求两数的最大公约数的方法是更相减损法。

四、实验小结

1.本次实验了解到辗转相除法的使用,巩固并熟悉递归函数的运用。
2.通过这次实验了解到自己身上的不足,仅靠书本是学不好C语言的,要在实验中一次次犯错,一次次积累经验。

posted @ 2021-06-06 23:19  丁哲航  阅读(57)  评论(0编辑  收藏  举报