• 作业5


    实验要求:

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

    # include<stdlib.h>
    int main()
    {
        int m,n,a,b,c=1;
        float sum=0;

            printf("输入两个正整数m和b且(m<=n)");
            scanf("%d%d",&m,&n);
            if((m>n)||(m<=0)||(n<=0))
    {
            printf("输入错误");
            exit(0);
    }
    for(a=m;a<=n;a++)
    {
            c=1;
    for(b=1;b<=a;b++)
    {
            c=c*b;
    }
            sum=sum+c;
    }
    printf("输出为%.2f",sum);
    return 0;
    }

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

    #include<stdio.h>
    int main ()
    {
        int i,j,n;
        for (i=2;i<=1000;i++)
        {
        n=1;
        for(j=2;j<i;j++)
        {
        if(i%j==0)
        {
        n=n+j;
        }
    }
        if(n==j)
        {
            printf("%d  ",i);
        }
    }
        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 a,i=0;
        printf("请输入一个数字");
        scanf("%d",&a);
        while(a!=1)
        {
    if(a%2==0) {
    a
    =a/2; i=i+1; } else if(a%2!=0) {a=3*a+1; i=i+1; } } printf ("%d",i); return 0; }

    附加题: 

      1.输入一个正整数n,输出2/1+3/2+5/3+8/5+…的前n项之和,保留2位小数,该序列从第二项起,每一项的分子是前一项分子与分母的和,分母是前一项的分子。 

    #include<stdio.h>
    int main ()
    {
        int a=1,b=2,c,d,x;
        float sum=0 ;
        printf("请输入数字");
        scanf ("%d",&x) ;
        for(c=1,a=1;a<=x;a++)
        {
    sum
    =sum+(float)b/c; d=c; c=b; b=b+d; } printf("%.2f",sum); return 0; }

    2.凯撒密码(caeser)的原理:每一个字母按字母表顺序向后移3位,如a加密后变成d,b加密后变成e,……x加密后变成a,y加密后变成b,z加密后变成c。例如:“baidu”用凯撒密码法加密后字符串变为“edlgx”。试写一个算法,将键盘输入的文本字符串(只包含a~z的字符)进行加密后输出。 

    #include <stdio.h>
    int main()
    {
        char c;
        printf("请输入一串字母
    ");
        while((c=getchar())!='
    ')
        {
            if(c>='A'&&c<='W'||c>='a'&&c<='w')
            {
                c=c+3;
            }
            else if(c>='X'&&c<='Z'||c>='x'&&c<='z')
            {
                c=c-23;
            }
            printf("%c",c);
        }
            
            return 0;
            } 

    实验知识点总结:

    1.循环语句for的格式。

    2.循环语句while的格式。

    3.嵌套语句的使用 ,连续使用两种循环 ,和循环和if语句的连用。

    4.变量的赋值

    实验总结:

    1.许多地方都要注意字母的中英文,尤其是输入完汉字之后总是会输入全角的英文,导致最后找错很麻烦。

    2.尤其要注意空格的使用 比如输出字符后面,输入字符后边 少输入空格到最后的找错也不太容易。

    3.注意等于和赋值的区别 。

    4.语句的使用要注意分号的使用 ,还有大括号的使用。还要注意执行的返回 ,是否结束。

    5.注意程序的合法性验证,应让程序更加完美。

  • 相关阅读:
    设置tomcat访问根路径
    关于Java抽象类的理解
    JavaIO
    synchronized关键字
    Java线程池
    Codeforces1478F-Nezzar and Nice Beatmap
    Codeforces1477B-Nezzar and Binary String
    Codeforces1476D Journey
    Codeforces1478D Nezzar and Board
    Codeforces Round #697 (Div. 3)G. Strange Beauty
  • 原文地址:https://www.cnblogs.com/wp980327/p/6028000.html
Copyright © 2020-2023  润新知