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

    一、实验内容 

       1.输入两个正整数m和n(要求m<=n), 求m!+(m+1)!+(m+2)!…+n!

    #include<stdio.h>
    int main()
    {
        int m,n,i=1,product=1,sum=0; 
        printf("请输入两个正整数:");
        scanf("%d%d",&m,&n);
        if(m<=n)
        {
            for(;m<=n;m++)
            {
                for(i;i<=m;i++)
                {
                product=product*i;
                }
                sum=sum+product;
            }
        }
        else if(m>n)
        {
            for(;n<=m;n++)
            {
                for(i;i<=n;i++)
                {
                product=product*i;
                }
                sum=sum+product;
            }
        }
        else
        {
            printf("输入的数据有误"); 
        }
        printf("%d",sum);
        return 0;
     } 

       2.输出1000以内的所有完数。所谓完数是指这个数恰好等于除他本身外的所有因子之和。例,6的因子为1,2,3,6=1+2+3,所以6是完数。 

    #include<stdio.h>
    int main()
    {
        int digit,yin,sum;
        for(digit=1;digit<=1000;digit++)
        {
            sum=0;
            for(yin=1;yin<digit;yin++)
            {
                if(digit%yin==0)
                sum=sum+yin;
            }
            if(sum==digit)
            printf("%4d",digit);
        }
        return 0;
     } 

    3.奇偶归一猜想——对于每一个正整数,如果它是奇数,则对它乘3再加1,如果它是偶数,则对它除以2,如此循环,最终都能够得到1。   如n = 11,得序列:11, 34, 17, 52, 26, 13, 40, 20, 10, 5, 16, 8, 4, 2, 1。(共有14个步骤)  题目输入正整数n,求这个n多少步能归一 

    #include<stdio.h>
    int main()
    {
        int digit,n=0;
        printf("请输入一个正整数:");
        scanf("%d",&digit);
        if(digit<=0)                                                                                                                                                                                                                                                                                                                                                                                                 
        {
            printf("输入的数据有误"); 
        }     
        while(digit!=1)
        { 
           if(digit%2==0)
           {
             digit=digit/2;
             n++;
           }   
            else if(digit%2==1)
           {
            digit=digit*3+1;
             n++;
           }
        } 
        printf("该数在运算%d步后归一",n);
        return 0;
    } 

     二、实验总结

    1理清程序中各个运算步骤顺序,分清大循环与小循环的顺序

    2要活用数据类型,注意各个数据类型的取值范围,防止出现数据溢出现象

    3单独的else后不能再接判断条件

    4要尽量将可能发生的所有情况都考虑到

  • 相关阅读:
    ABAP 销售范围
    C语言深度剖析自测题8解析
    Ubutun13.10下安装fcitx
    各种Web服务器与Nginx的对比
    Hadoop2.2.0在Ubuntu编译失败解决方法
    网站上在给出邮箱地址时不直接使用@符号的原因
    IPython notebook在浏览器中显示不正常的问题及解决方法
    input只读效果
    阿里实习生电面题目:输出给定字符串的全部连续子串
    DNS 放大
  • 原文地址:https://www.cnblogs.com/UUZsama/p/6020966.html
Copyright © 2011-2022 走看看