• 第七次作业


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

    #include<stdio.h>
    int isprime(int x);
    int main()
    {
        int num=0,n;
        for(n=2;n<=1000;n++)
        {
            if(isprime(n))
            {
                printf("%4d ",n);
                num++;
                if(num%10==0)
                {
                    printf("
    ");
                }
            }
        }
        printf("一共%d个数
    ",num);
        return 0;
    }
    int isprime(int x)
    {
        int i,flag=1;
        for(i=2;i<=x-1;i++)
        {
            if(x%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 m,int n);
    int main()
    {
        int x,y,temp,b,k;
        printf("请输入两个数,求最大公约数和最小公倍数:
    ");
        scanf("%d%d",&x,&y);
        if(x<=0||y<=0||x==y)
        {
            printf("输入错误
    ");
            exit(0);
        }
        if(y>x)
        {
            temp=x;
            x=y;
            y=temp;
        }
        b=gcd(x,y);
        k=lcm(x,y);
        printf("最大公约数为%d,最小公倍数为%d
    ",b,k);
        return 0;
    }
    int gcd(int a,int b)
    {
        int c;
        do
        {
            c=a%b;
            a=b;
            b=c;
        }while(c!=0);
        return a;
    }
    int lcm(int m,int n)
    {
        int k;
        k=m*n/gcd(m,n);
        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的值。

       样例:

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

    #include<stdio.h>
    #include<math.h>
    double fun(double x);
    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=%.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 x);
    int main()
    {
        int a,b,c,sum;
        for(a=0;a<=9;a++)
        for(b=0;b<=9;b++)
        {
            c=a+b;
            if(c>9)
            {
                continue;
            }
            sum=fun(a)+fun(b)+fun(c);
            if(sum==12)
            {
                printf("%d+%d=%d
    ",a,b,c);
            }
        }
        return 0;
    }
    int fun(int x)
    {
        int x1;
        switch(x)
            {
                case 1:x1=2;break;
                case 4:x1=4;break;
                case 7:x1=3;break;
                case 8:x1=7;break;
                case 2:
                case 3:
                case 5:x1=5;break;
                case 0:
                case 6:
                case 9:x1=6;break;
            }
        return x1;
    }

    二、知识点总结

    1.学会怎么写函数,和怎么调用函数;

    2.一定要在开头的地方声明函数,建议刚开始先空出来地方等写完函数后 在将其复制粘贴过去;

    3.函数中只能有一个返回值 而且不能有输出;

    4.实参就是在主函数中输入的数,形参就是在函数中用到的数(假如主函数你输入的是a,函数中你定义的是x 那么实参就是a,形参就是x);

    5.求公约数用到了辗转相除法(两个数中大的除小的,然后再用小的除余数,一直循环知道余数为0,则最后的除数就是最大公约数),最小公倍数(两数相乘除以最大公约数)。

    三、实验总结(实验中遇到的问题及解决方法) 

    1.要在函数前声明变量类型,如果没说 那就是默认的int型的;

    2.经常出现的小问题就是英文字母打错来了,括号不匹配,变量不对应,忘记加封号,输出时忘记写输出的值只写了要输出的话。

  • 相关阅读:
    Educational Codeforces Round 15 C. Cellular Network(二分)
    HDU 1044 Collect More Jewels(BFS+DFS)
    NBOJv2 Problem 1009 蛤玮的魔法(二分)
    HDU 1016 Prime Ring Problem(经典DFS+回溯)
    HDU 2181 哈密顿绕行世界问题(经典DFS+回溯)
    OpenCV学习笔记——滑动条开关
    廖雪峰Java15JDBC编程-3JDBC接口-3JDBC更新
    廖雪峰Java15JDBC编程-3JDBC接口-1JDBC简介
    廖雪峰Java15JDBC编程-2SQL入门-2insert/select/update/delete
    廖雪峰Java15JDBC编程-2SQL入门-1SQL介绍
  • 原文地址:https://www.cnblogs.com/zj1220/p/6079013.html
Copyright © 2020-2023  润新知