zoukankan      html  css  js  c++  java
  • 作业4 函数应用

    1、输入2个正整数m和n(1≤m,n≤1000),输出m~n之间的所有水仙花数。水仙花数是指各位数字的立方和等于其自身的数。要求定义并调用函数is(number)判断number的各位数字之和是否等于其自身。

    #include<stdio.h>
    #include<math.h>
    int main(void)
    {
        int n,m,i;//n<=1,m>=1000
        int x,y,z;//x是个位数,y是十位数字,z是百位数字
        x=0,y=0,z=0;
        printf("enter m,n:");
        scanf("%d%d",&m,&n);
        for(i=m;i<=n;i++){
            x=i%10;
            y=(i/10)%10;
            z=i/100;
            if(pow(x,3)+pow(y,3)+pow(z,3)==i)
                printf("i=%d
    ",i);
            if(x+y+z==i)
              printf("%d各位数字之和等于其自身
    ",i);
        }
        return 0;
    }

    2、编写一个程序,判断从键盘接收的数字是否为回文数字。回文数字就是顺着看和倒着看是相同的数。如121、656、2332等。

    #include<stdio.h>
    int main(void)
    {
        int i,n;
        int x,y;//x是从头开始计算的数组下标,而y是从末尾开始计算的数组下标
        x=0;
        y=0;
        printf("enter n:");
        scanf("%d",&n);
        //定义并输入数组
        int a[80];
        for(i=1;i<n;i++)
        {
            printf("enter a[]:");
            scanf("%d",&a[i]);
        }
        for(x=0,y=n;x<y;x++,y--)
        {
            if(a[x]!=a[y])//判断首尾两个字符是否相等,若不相等则不需要继续
                break;
        }
    
        if(x>=y)//for循环正常结束,是回文
            printf("是回文。");
        else
            printf("不是回文");
        return 0;
    }

    3、找出11~999之间的所有的三重回文数字。所谓三重回文数a就是指a、a2、a3都是回文数字。

    4、输入x、n后输出下列算式的值,fact(n)实现n!,mypow(x,n)实现x^n。

    #include<stdio.h>
    #include<math.h>
    int main(void)
    {
        int x,i,n;
        double s;
        s=0;
        double fact(int n);
        double mypow(int x,int n);
        printf("enter x,n:");
        scanf("%d%d",&x,&n);
        for(i=1;i<=n;i++)
        {
            s=s+pow(-1,i-1)*mypow(x,n)/fact(n);
        }
        printf("s=%.3f",s);
        return 0;
    }
    //计算n的阶层
    double fact(int n)
    {
        int i;
        double result;
        result=1;
        for(i=1;i<=n;i++)
        {
            result=1*result;
        }
        return result;
    }
    //不用数学公式,用调用函数计算x^n
    double mypow(int x,int n)
    {
        double result;
        result=1;
        int i;
        for(i=1;i<=n;i++){
            result=result*x;
        }
        return result;
    }

     5、按下面要求编写程序:
    (1)定义函数f(n)计算n+(n+1)+…+(2n-1),函数返回值类型是double。
    (2)在主函数main(),输入正整数n,计算并输出下列算式的值。要求调用函数f(n)计算n+(n+1)+…+(2n-1)。

    #include<stdio.h>
    int main(void)
    {
        double f(int n);
        double s=0;
        int n;
        printf("enter n:");
        scanf("%d",&n);
        //自定义函数f(n)来计算
        s=f(n)+s;
        //输出s的值
        printf("s=%.3f",s);
        return 0;
    }
    double f(int n)
    {
        double result,t;
        int i;
        
        result=0;
        t=0;
        //循环整个的
        for(i=1;i<=n;i++){
            //输出每个的小部分
            for(i=1;i<=2*n-1;i++)
            {
                t=i+t;
            }
            result=result+1/t;
        }
        return result;
    }
  • 相关阅读:
    Layui数据表格的使用
    单选按钮和下拉框默认选中
    平方探测法处理散列函数冲突
    ssh框架整合笔记---配置文件
    第二十九个知识点:什么是UF-CMA数字签名的定义?
    第二十八个知识点:什么是公钥密码学的IND-CCA安全定义?
    第二十七个知识点:什么是对称密码加密的AEAD安全定义?
    第二十六个知识点:描述NAF标量乘法算法
    第二十五个知识点:使用特殊的素数定义$GF(p)$和$GF(2^n)$的方法。
    第二十四个知识点:描述一个二进制m组的滑动窗口指数算法
  • 原文地址:https://www.cnblogs.com/wuyanlong/p/3417201.html
Copyright © 2011-2022 走看看