• 第七次作业


    一.实验内容

    1.

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

    代码:

    #include<stdio.h>
    int isprime(int x);
    int isprime(int x)
    {
        int a,b=1;
        for(a=2;a<=x-1;a++)
        {
            if(x%a==0)
            {
                b=0;
                break;
            }
        }
        if(b==1)
            return 1;
        else
            return 0;
    }
    int main()
    {
        int i,d=0;
        for(i=2;i<=1000;i++)
        {
            if(isprime(i))
            {
                printf("%3d ",i);
                d++;
                if(d%10==0)
                printf("
    ");
            }
        }
        printf("共有%d个素数。
    ",d);
        return 0;
    }

    运行结果:

    2.

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

    代码:

    #include<stdio.h>
    int gcd(int a,int b);
    int lcm(int a,int b);
    int gcd(int a,int b)
    {
        int i,x,c;
        if(b>a)
        {
            x=b;
            b=a;
            a=x;
        }
        while(1)
        {
            c=a%b;
            if(c==0)
            {
                break;
            }
            a=b;
            b=c;
        }
        return b;
    }
    int lcm(int a,int b)
    {    int d;
        d=a*b/gcd(a,b);
    }
    int main()
    {
        int num1,num2;
        printf("请输入两个正整数,用逗号隔开。
    ");
        scanf("%d,%d",&num1,&num2);
        printf("最大公约数为%d,最小公倍数为%d。
    ",gcd(num1,num2),lcm(num1,num2));
    }

    运行结果:

    3.

    实验要求:

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

           y1= 2²-5*2+4

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

           y3= sin²x-5*sinx+4    

    代码:

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

    运行结果:

    4.

    实验要求:用函数实现:火柴棍等式问题。

    代码:

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

    运行结果:

    二.知识点总结

    一个函数只能返回一个值

    如果不声明函数类型,默认是int

    不同函数是平等的,不能嵌套

    运用辗转相除法求最大公因数再根据最大公因数求最小公倍数

    三.实验总结:

    声明自定义函数末尾要加分号

  • 相关阅读:
    What are the difference between DDL, DML and DCL commands?
    Dingjun123 :使用Partitioned Outer Join实现稠化报表
    Oracle Clusters
    Google实验室能力倾向测试(第一题及解答)
    搜索系统中基于字典的逆向中文分词
    vc++ 深入浅出 窗口创建过程
    计算机网络基础知识1
    线性代数学习之对称矩阵与矩阵的SVD分解
    珍爱生命
    str2hash
  • 原文地址:https://www.cnblogs.com/kbx1602/p/6083540.html
Copyright © 2020-2023  润新知