zoukankan      html  css  js  c++  java
  • 第七次作业

    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。

  • 相关阅读:
    【转】概率主题模型简介 Introduction to Probabilistic Topic Models
    codility: Fibonacci numbers (FibFrog, Ladder)
    codility: Euclidean algorithm ( ChocolatesByNumbers, CommonPrimeDivisors)
    effective c++ 11: Handle assignment to self in operator =
    effective c++ 10: Have assignment operators return a reference to *this
    effective c++ 9: Never call virtual functions during construction or destruction
    JDBC连接数据库基础
    day14
    集合方法
    day10
  • 原文地址:https://www.cnblogs.com/1998li/p/6081838.html
Copyright © 2011-2022 走看看