• 第五次作业


    一、实验内容 

       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要尽量将可能发生的所有情况都考虑到

  • 相关阅读:
    相对定位和绝对定位
    Html中常见的块级元素
    浮动的用法
    c#中质数判断
    函数
    asp.net Jquery+json 实现无刷新分页
    MS CRM2011 某个用户(团队)对某个实体的操作权限
    asp.net sitemap url动态参数
    MS CRM 2011 更改团队的业务部门
    MS CRM 2011 解决记录总数问题
  • 原文地址:https://www.cnblogs.com/UUZsama/p/6020966.html
Copyright © 2020-2023  润新知