• 面向过程程序设计——循环结构程序设计(1)


    7-1求平方与倒数序列的部分和

    本题要求对两个正整数m和n(m≤n)编写程序,计算序列和m2+1/m+(m+1)2+1/(m+1)+⋯+n2+1/n。

    输入格式:

    输入在一行中给出两个正整数m和n(m≤n),其间以空格分开。

    输出格式:

    在一行中按照“sum = S”的格式输出部分和的值S,精确到小数点后六位。题目保证计算结果不超过双精度范围。

    输入样例:

    5 10
    

    输出样例:

    sum = 355.845635
    1. #include<stdio.h>
    2. int main()
    3. {
    4. int m=0;
    5. int n=0;
    6. double sum=0;
    7. scanf("%d %d",&m,&n);
    8. int i=0;
    9. for(i=m;i<=n;i++)
    10. {
    11. sum=sum+i*i+1/(double)i;
    12. }
    13. printf("sum = %.6lf",sum);
    14. return 0;
    15. }

     7-2 输出整数各位数字

    本题要求编写程序,对输入的一个整数,从高位开始逐位分割并输出它的各位数字。

    输入格式:

    输入在一行中给出一个长整型范围内的非负整数。

    输出格式:

    从高位开始逐位输出该整数的各位数字,每个数字后面有一个空格。

    输入样例:

    123456
    

    输出样例:

    1 2 3 4 5 6 
    1. #include<stdio.h>
    2. int main()
    3. {
    4. long a=0;
    5. scanf("%ld",&a);
    6. long count =1;
    7. long b=a;
    8. while((b/10)!=0)
    9. {
    10. b/=10;
    11. count*=10;
    12. }
    13. while(count!=0)
    14. {
    15. printf("%ld ",a/count);
    16. a%=count;
    17. count/=10;
    18. }
    19. return 0;
    20. }

    7-3 求e的近似值

    自然常数 e 可以用级数 1+1/1!+1/2!+⋯+1/n!+⋯ 来近似计算。本题要求对给定的非负整数 n,求该级数的前 n+1 项和。

    输入格式:

    输入第一行中给出非负整数 n(≤1000)。

    输出格式:

    在一行中输出部分和的值,保留小数点后八位。

    输入样例:

    10
    

    输出样例:

    2.71828180
    1. #include<stdio.h>
    2. int main()
    3. { int n,i; double b=1,sum=0;
    4. scanf("%d",&n);
    5. for(i=1;i<=n;i++)
    6. { b*=i;
    7. sum+=1.0/b;
    8. }
    9. printf("%.8lf",sum+1);
    10. return 0;
    11. }

     7-4 高空坠球

    皮球从某给定高度自由落下,触地后反弹到原高度的一半,再落下,再反弹,……,如此反复。问皮球在第n次落地时,在空中一共经过多少距离?第n次反弹的高度是多少?

    输入格式:

    输入在一行中给出两个非负整数,分别是皮球的初始高度和n,均在长整型范围内。

    输出格式:

    在一行中顺序输出皮球第n次落地时在空中经过的距离、以及第n次反弹的高度,其间以一个空格分隔,保留一位小数。题目保证计算结果不超过双精度范围。

    输入样例:

    33 5
    

    输出样例:

    94.9 1.0
    1. #include<stdio.h>
    2. #include<math.h>
    3. int main()
    4. {
    5. int i,h,n;
    6. float s=0.0,z=0.0,k=2.0;
    7. scanf("%d %d",&h,&n);
    8. if(n>0) {
    9. s=h;
    10. for(i=1;i<=n;i++){
    11. s=s+2.0*z;
    12. z=h/k;
    13. k=k*2;
    14. }
    15. }
    16. printf("%0.1f %0.1f",s,z);
    17. return 0;
    18. }

     7-5 人民币兑换

    1元5角钱人民币兑换5分、2分和1分的硬币(每一种都要有)共100枚,会有很多种兑换方案。请编写程序给出各种兑换方案。

    输入格式:

    输入为一个正整数n,表示要求输出前n种可能的方案。方案的顺序,是按照5分硬币从少到多排列的。

    输出格式:

    显示前n种方案中5分、2分、1分硬币各多少枚。每行显示一种方案,数字之间空一格,最后一个数字后没有空格。

    注意:如果全部方案不到n种,就顺序输出全部可能的方案。

    输入样例:

    5
    

    输出样例:

    1. 1 46 53
    2. 2 42 56
    3. 3 38 59
    4. 4 34 62
    5. 5 30 65
    1. #include<stdio.h>
    2. int main()
    3. {
    4. int n=0;
    5. scanf("%d",&n);
    6. int i,j,k;
    7. int count=0;
    8. for(i=1;i<100;i++)
    9. {
    10. for(j=1;j<100;j++)
    11. {
    12. for(k=1;k<100;k++)
    13. {
    14. if(i+j+k == 100 && i*5+2*j+k == 150)
    15. {
    16. count++;
    17. if(count<n)
    18. {
    19. printf("%d %d %d\n",i,j,k);
    20. }
    21. if(count == n)
    22. printf("%d %d %d",i,j,k);
    23. }
    24. }
    25. }
    26. }
    27. return 0;
    28. }

    7-6 求整数的位数及各位数字之和

    对于给定的正整数N,求它的位数及其各位数字之和。

    输入格式:

    输入在一行中给出一个不超过109的正整数N。

    输出格式:

    在一行中输出N的位数及其各位数字之和,中间用一个空格隔开。

    输入样例:

    321
    

    输出样例:

    3 6

    1. #include<stdio.h>
    2. int main()
    3. {
    4. int n=0;
    5. scanf("%d",&n);
    6. int count=0;
    7. int sum=0;
    8. while(n!=0)
    9. {
    10. sum+=n%10;
    11. count++;
    12. n/=10;
    13. }
    14. printf("%d %d",count,sum);
    15. return 0;
    16. }

    7-7 打印菱形图案

    本题要求编写程序,打印一个高度为n的、由“*”组成的正菱形图案。

    输入格式:

    输入在一行中给出一个正的奇数n。

    输出格式:

    输出由n行星号“*”组成的菱形,如样例所示。每个星号后跟一个空格。

    输入样例:

    7
    

    输出样例:

    1. *
    2. * * *
    3. * * * * *
    4. * * * * * * *
    5. * * * * *
    6. * * *
    7. *
    1. #include<stdio.h>
    2. int main()
    3. {
    4. int n=0;
    5. scanf("%d",&n);
    6. if(n%2!=0)
    7. {
    8. for(int i=1;i<=n/2+1;i++)
    9. {
    10. for(int j=1;j<=(n+1)/2-i;j++)
    11. {
    12. printf(" ");
    13. }
    14. for(int m=1;m<=2*i-1;m++)
    15. {
    16. printf("* ");
    17. }
    18. printf("\n");
    19. }
    20. for(int l=1;l<=n/2;l++)
    21. {
    22. for(int z=1;z<=l;z++)
    23. {
    24. printf(" ");
    25. }
    26. for(int k=1;k<=n-2*l;k++){
    27. printf("* ");
    28. }
    29. printf("\n");
    30. }
    31. }
    32. return 0;
    33. }

    7-8 找完数

    所谓完数就是该数恰好等于除自身外的因子之和。例如:6=1+2+3,其中1、2、3为6的因子。本题要求编写程序,找出任意两正整数m和n之间的所有完数。

    输入格式:

    输入在一行中给出2个正整数m和n(1

    输出格式:

    逐行输出给定范围内每个完数的因子累加形式的分解式,每个完数占一行,格式为“完数 = 因子1 + 因子2 + ... + 因子k”,其中完数和因子均按递增顺序给出。若区间内没有完数,则输出“None”。

    输入样例:

    2 30
    

    输出样例:

    1. 6 = 1 + 2 + 3
    2. 28 = 1 + 2 + 4 + 7 + 14
    1. #include <stdio.h>
    2. int main()
    3. {
    4. int i, m, n;
    5. scanf("%d %d", &m, &n);
    6. int count = 0;
    7. for (i = m; i <= n; i++)
    8. {
    9. int sum = 0, a, b;
    10. for (a = 1; a < i; a++)
    11. {
    12. b = i % a;
    13. if (b == 0)
    14. sum = sum + a;
    15. }
    16. if (sum == i) {
    17. printf("%d = 1", sum);
    18. int c, d;
    19. for (c = 2; c < i; c++)
    20. {
    21. d = i % c;
    22. if (d == 0)
    23. printf(" + %d", c);
    24. }
    25. printf("\n"); count = count + 1;
    26. }
    27. }
    28. if (count == 0)
    29. printf("None");
    30. }

    7-9 求整数段和

    给定两个整数A和B,输出从A到B的所有整数以及这些数的和。

    输入格式:

    输入在一行中给出2个整数A和B,其中−100≤A≤B≤100,其间以空格分隔。

    输出格式:

    首先顺序输出从A到B的所有整数,每5个数字占一行,每个数字占5个字符宽度,向右对齐。最后在一行中按Sum = X的格式输出全部数字的和X

    输入样例:

    -3 8
    

    输出样例:

    1. -3 -2 -1 0 1
    2. 2 3 4 5 6
    3. 7 8
    4. Sum = 30

    1. #include<stdio.h>
    2. int main()
    3. {
    4. int a=0;
    5. int b=0;
    6. int x=0;
    7. int Sum=0;
    8. scanf("%d %d",&a,&b);
    9. for(int i=a;i<=b;i++)
    10. {
    11. printf("%5d",i);
    12. x++;
    13. if(x%5==0&&i!=b)
    14. {
    15. printf("\n");
    16. }
    17. Sum+=i;
    18. }
    19. printf("\n");
    20. printf("Sum = %d",Sum);
    21. return 0;
    22. }

    7-10 验证“哥德巴赫猜想”

    数学领域著名的“哥德巴赫猜想”的大致意思是:任何一个大于2的偶数总能表示为两个素数之和。比如:24=5+19,其中5和19都是素数。本实验的任务是设计一个程序,验证20亿以内的偶数都可以分解成两个素数之和。

    输入格式:

    输入在一行中给出一个(2, 2 000 000 000]范围内的偶数N。

    输出格式:

    在一行中按照格式“N = p + q”输出N的素数分解,其中p ≤ q均为素数。又因为这样的分解不唯一(例如24还可以分解为7+17),要求必须输出所有解中p最小的解。

    输入样例:

    24
    

    输出样例:

    24 = 5 + 19

    1. #include<stdio.h>
    2. #include<math.h>
    3. int sushu(int n)
    4. {
    5. int i;
    6. int k;
    7. int a;
    8. k=(int)sqrt( (double)n);//强制类型转换
    9. for(i=2;i<=k;i++)
    10. if(n%i==0)
    11. break;
    12. // 如果完成所有循环,那么m为素数
    13. // 注意最后一次循环,会执行i++,此时 i=k+1,所以有i>k
    14. if(i>k)
    15. a=1;
    16. else
    17. a=0;
    18. return a;
    19. }
    20. //函数的作用是判断素数
    21. int main()
    22. {
    23. int n, i;
    24. scanf( "%d", &n );
    25. for( i = 2; i <= n / 2; i++ )
    26. {
    27. if( sushu( i ) && sushu( n - i ) )//判断两个相加的数是不是同时为素数
    28. {
    29. printf( "%d = %d + %d\n", n, i, n - i );
    30. break;
    31. }
    32. }
    33. return 0;
    34. }

  • 相关阅读:
    StringBuilder类用法解析
    提升科研可复现性:和鲸聚焦 AI for Science 全生命周期管理
    MySQL如何导入大量数据?
    1秒钟搞懂tee和vim文件的使用命令(超级详细)
    自定义注解,利用AOP实现日志保存(数据库),代码全贴,复制就能用
    Programiranje 方法记录
    mysql报错:mysql8插入sql关键字“rank”问题
    Centos7 安装Docker以及图形管理界面
    医院为什么需要信息集成平台?有什么数据集成平台推荐?
    ARM-day9作业
  • 原文地址:https://blog.csdn.net/LxinY213/article/details/127818256