C语言实验报告(五)

姓   名:谢晨 
实验地点:家                      
实验时间: 2020年4月21日                
实验项目:

4.3.1-1求三角形面积 4.3.1-2求阶乘 4.3.1-3求最大公约数 4.3.1-4打印三角形 4.3.2-1500以内的亲密数对 4.3.3-1x^y次幂

一、实验目的与要求

1.熟练地掌握函数的定义方法和调用规则。
2.掌握在C语言程序中主调函数与被调函数之间进行数据传递的规则。
3.了解函数的返回值及其类型,并正确使用它。
4.了解局部变量和全局变量的作用域及它们与存储分类的关系,理解变量的存在性和可见性的概念
5.练习递归函数的使用

若正整数A的所有因子( 包括1但不包括自身,下同)之和为B,而B的因子之和为A,则称A和B为一对亲密数。求出500以内的所有亲密数对

编写程序,分别从键盘输人数据x和y,计算x的y次幂并输出。

二、实验内容

1、4.3.1-1求三角形面积

1问题的简单描述:编写程序,从键盘输人三角形的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);
}  
int main()
{
    float a,b,c,ts;
    printf("输入三条边:");
    scanf("%f,%f,%f",&a,&b,&c);
    ts=area(a,b,c);
    if(a+b>c&&a+c>b&&b+c>a)
    printf("area=%f\n",ts);
    else printf("Data error!");
}

3问题分析:数据类型要前后注意。

2、4.3.1-2求阶乘

1问题的简单描述:编写函数,求出从主调函数传来的数值i的阶乘值,然后将其传回主调函数并输出。

2实验代码:

#include <stdio.h>
#define N 5
long function(int i)
{
    static long f=1;
    f=f*i;
    return f;
}
int main()
{
    long product;
    int i;
    for(i=1;i<=N;i++)
    {
       product=function(i);
       printf("%d的阶乘是%d\n",i,product);    
    }    
}

3问题分析:无

3、4.3.1-3求最大公约数

1问题的简单描述:编写程序,从键盘输人两个整数,调用gcd()函数求它们的最大公约数,并输出结果。

2实验代码:

#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;
}
    int main()
    {
        int x,y;
        int fac;
        printf("Please input two integers:\n");
        scanf("%d,%d",&x,&y);
        fac=gcd(x,y);
        printf("The great common divisor is%d",fac);
    }

3问题分析:a,b值进行交换时忘记用中间值导致结果有误。

4、4.3.1-4打印三角形

1问题的简单描述:输入整数n,输出高度为n的等边三角形

2实验代码:

#include <stdio.h>
void trangle(int n)
{
    int i,j;
    for(i=0;i<n;i++)
    {
        for(j=i;j<n;j++)
        printf(" ");
        for(j=0;j<=(2*i);j++)
        printf("*");
        putchar('\n');
    }
}
int main()
{
    int n;
    printf("Please input a integer:");
    scanf("%d",&n);
    printf("\n");
    trangle(n);
}

3问题分析:无

5、4.3.2-1500以内的亲密数对

1问题的简单描述:若正整数A的所有因子( 包括1但不包括自身,下同)之和为B,而B的因子之和为A,则称A和B为一对亲密数。求出500以内的所有亲密数对

2实验代码:

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

3问题分析:无

6、实验6.3.2.3

1问题的简单描述:计算Ackerman函数

2实验代码:

#include<stdio.h>
int Ack(int n,int x,int y)
{
    int a;
    if(n==0)
    a=x+1;
    if(n==1&&y==0)
    a=x;
    if(n==2&&y==0)
    a=0;
    if(n==3&&y==0)
    a=1;
    if(n>=4&&y==0)
    a=2;
    if(n!=0&&y!=0)
    a=Ack(n-1,Ack(n,x,y-1),x); 
    return a;    
}
main()
{
    int n,x,y,result;
    printf("Please input n,x,y:");
    scanf("%d,%d,%d",&n,&x,&y);
    if(n<0||x<0||y<0)
    printf("Input error please input again:");
    result=Ack(n,x,y);
    printf("Ack(%d,%d,%d)=%d\n",n,x,y,result);
}

3问题分析:无

实验拓展:汉诺塔问题

1思路:汉诺塔是经典的递归思想的问题,熟悉c语言中的递归结构

2实验代码:

#include <stdio.h> 
move(int n,char x,char y)
{
    static int m=1;
    printf("%d:%d from%c-->%c",m++,n,x,y);
}
 hanoi(int n,char a,char b,char c)//把n个盘子从a移到c
{
    if(n==1)
    move(n,a,c);
    else
    {
        hanoi(n-1,a,c,b);//把n-1个盘子借助c从a移到b
        move(n,a,c);//第n个盘子从a移到c 
        hanoi(n-1,b,a,c);//把b上的n-1个盘子借助a移到c 
    }
int main()
{
    int n;
    printf("请输入盘子个数:");
    scanf("%d",&n);
    printf("%d盘子移动步骤如下:",n);
    hanoi(n,a,b,c);
}
     
}

3问题分析:在思考该问题时,参考了网络上的代码,发现不同的程序员对于同一代码的思考不同,代码也不同,而我积累的太少。希望能通过以后的学习,更多的了解学习c语言,将它变成自己的一项技能。

 

posted @ 2020-04-26 20:59  explore~  阅读(556)  评论(0)    收藏  举报