• 第七次作业


    1. 定义一个判断素数的函数isprime(int n),利用该函数输出1000以内的所有素数,每行10个,最后输出一共有多少个素数。(每列对齐)

    #include<stdio.h>
    #include<math.h>
    int isprime(int n);
    int main()
    {
        int a,b=0;
        for(a=2;a<=1000;a++)
        {
            if(isprime(a))
            {
                printf("% 4d ",a);
                b++;
                if(b%10==0)
                {
                    printf("
    ");
                }
            }
        }
        printf("一共%d个数
    ",b);
        return 0;
    }
    int isprime(int n)
    {
        int i,flag=1;
        for(i=2;i<=n-1;i++)
        {
            if(n%i==0)
            {
                flag=0;
            }
        }
        if(flag==1)
        {
            return 1;
        }
        else
        {
            return 0;
        }
    }

     2.求两个正整数的最大公约数和最小公倍数。用一个函数gcd(int a,int b)求最大公约数,另一个函数lcm(int a,int b)根据求出的最大公约数求最小公倍数。

    #include<stdio.h>
    #include<stdlib.h>
    int gcd(int a,int b);
    int lcm(int a,int b);
    int main()
    {
        int c,d,e,b,k;
        scanf("%d%d",&c,&d);
        if(c<=0||d<=0||c==d)
        {
            printf("error");
            exit(0);
        }
        if(d>c)
        {
            e=c;
            c=d;
            d=e;
        }
        b=gcd(c,d);
        k=lcm(c,d);
        printf("最大公约数为%d,最小公倍数为%d",b,k);
        return 0;
    }
    int gcd(int a,int b)
    {
        int f;
        while(1)
        {
            f=a%b;
            if(f==0)
            {
                break;
            }
            a=b;
            b=f;
        }
        return b;
    }
    int lcm(int a,int b)
    {
        int k;
        k=a*b/gcd(a,b);
        return k;
    }

    3.编写一个函数fun(double x)求表达式x2-5x+4的值,x作为参数传给函数。在主函数中调用该函数求下列式子的值:

           y1= 22-5*2+4

           y2= (x+15)2-5*(x+15)+4

           y3= sin2x-5*sinx+4    

       求y3用数学函数 sin(x)  头文件math.h

       求解y2和y3时需要输入x的值。

    #include<stdio.h>
    #include<math.h>
    double fun(double x);
    int main()
    {
        double y1,y2,y3,x;
        scanf("%lf",&x);
        y1=fun(2);
        y2=fun(x+15);
        y3=fun(sin(x));
        printf("y1=%.2lf,y2=%.2lf,y3=%lf",y1,y2,y3);
        return 0;
    }
    double fun(double x)
    {
        double y;
        y=x*x+5*x+4;
        return y;
    }

    4.用函数实现:火柴棍等式问题。

    #include<stdio.h>
    int fun(int a);
    int main()
    {
        int x,y,z,sum;
        for(x=0;x<=9;x++)
            for(y=0;y<=9;y++)
            {
                z=x+y;
                if(z>9)
                {
                    break;
                }
                sum=fun(x)+fun(y)+fun(z);
                if(sum==12)
                {
                    printf("%d+%d=%d
    ",y,x,z);
                }
            }
                return 0;
        }
    int fun(int a)
    {
        int b;
        switch(a)
        {
            case 0:
            case 6:
            case 9:b=6;break;
            case 1:b=2;break;
            case 2:
            case 3:
            case 5:b=5;break;
            case 4:b=4;break;
            case 7:b=3;break;
            case 8:b=7;break;
        }
        return b;
    }
                    

    二、知识点总结

    1、函数的返回值:执行完函数体后,会产生一个结果,返回给主调函数处理。

    2、一个return语句只能返回一个值。

    3、在定义函数时对函数值说明的类型一般应该和return语句中的表达式类型一致。

    4、c语言中不允许在函数体内嵌套定义函数。

    三、实验总结

    1、最后输出的printf不能有&。

    2、switch中的语句要用{}括起来。

    3、注意函数的返回值是谁。

    4、while语句后面不能加;

    5、double语句中scanf里面要用%lf。

  • 相关阅读:
    软工实践个人总结
    实验 7:OpenDaylight 实验——Python 中的 REST API 调用(含选做)
    2020软工实践第二次结对作业
    mocha单元测试简单教程
    实验 6:OpenDaylight 实验——OpenDaylight 及 Postman实现流表下发
    实验 5:OpenFlow 协议分析和 OpenDaylight 安装
    实验 4:Open vSwitch 实验——Mininet 中使用 OVS 命令
    福州大学软件工程实践第一次个人编程作业
    实验 3:Mininet实验 —— 测量路径的损耗率
    实验 2:Mininet 实验——拓扑的命令脚本生成
  • 原文地址:https://www.cnblogs.com/1998li/p/6081838.html
Copyright © 2020-2023  润新知