• 实验七


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

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

     

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

    #include<stdio.h>
    int gcd(int a,int b)
    {
        int i,m;
        for(m=a;m>1;m--)
           for(i=b;i>1;i--)
        {
            if(a%m==0&&b%i==0&&m==i)
            {
                return m;
            }
        }
    }
    int lcm(int a,int b)
    {
        int c;
        c=a*b/gcd(a,b);
        return c;
    }
    int main()
    {
        int n,x,z,y;
        printf("请输入两个正整数");
        scanf("%d%d",&n,&x);
        if(n<0||x<0)
        {
            printf("输入错误");
        }
        else 
        {
            z=gcd(n,x);
            y=lcm(n,x);
        }
        printf("两个正整数的最大公约数是%d",z);
        printf("两个正整数的最小公倍数是%d",y);
        return 0;
    }

     

       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的值。

       样例:

       y1=-2, x=0.5时,y2=166.75,y3=1.832721

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

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

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

     实验总结:

    (1)注意数据的类型

    (2)注意返回值的类型

    (3)注意开始时附初始值

    (4)不要忘return语句

    (5)注意int和double类型的转换

    (6)注意被调用的函数一定是已存在的函数

    知识点总结:

    (1)函数体内不能嵌套函数

    (2)函数中可以有多个return语句

    (3)函数的调用形式是:函数名(实参表)

    (4)函数首部,以分号结尾,构成函数的原型

    (5)程序控制权交给被调函数,执行函数内的语句,当执行到return语句时,从函数退出

  • 相关阅读:
    intent-filter 之 data 「scheme, host, port, mimeType, path, pathPrefix, pathPattern」
    Android 自定义RecyclerView 实现真正的Gallery效果
    Android手势监听类GestureDetector的使用
    Android 屏幕手势滑动中onFling()函数的技巧分析
    onTouchEvent方法的使用
    Android 手势&触摸事件
    android关闭日志
    android intent和intent action大全
    调用新浪微博显示用户信息
    android 反编译
  • 原文地址:https://www.cnblogs.com/lr97/p/6067260.html
Copyright © 2020-2023  润新知