C语言练习

输出7 和7 的倍数,还有包含7 的数字例如(17,27,37,...,70,71,72,73,...)

2.需求分析

输出7 和7 的倍数,还有包含7 的数字,从小到大排列的不大于N 的与7 有关的数字,每行一个

(1)  输入的形式和输入值的范围:输入一个整型数据,输入值范围n<30000

(2)   输出的形式:每行输出一个符合条件的数

(3)  程序所能达到的功能:分行输出7 和7 的倍数,还有包含7 的数字

(4)  测试数据: 输入29 输出 7 14 17 21 27 28

3.概要设计

for循环从7到输入的数找符合条件的数

4.用户使用说明

当界面出现 Enter munber <30000:

即可输入数字 等待结果

5.测试结果

6.附录

#include<stdio.h>

void main()

{

int x,i;

printf("Enter munber<30000:\n");

scanf("%d",&x);

if(x>30000)

return ;

else

for(i=7;i<x;i++)

if(i%7==0||i%10==7||(i/10)==7||(i/100)==7||(i/1000)==7||(i/10000)==7)

//依次为7的倍数 个数为7 十位数为7 百位数为7 千位数为7 万位数为7

printf("%d\n",i);

}


第四平方和定理,又称为拉格朗日定理:每个正整数都可以表示为至多4个正整数的平方和。如果把0包括进去,就正好可以表示为4个数的平方和。比如:5 = 0^2 + 0^2 + 1^2 + 2^2 ,7 = 1^2 + 1^2 +1^2 + 2^2 (^符号表示乘方的意思)对于一个给定的正整数,可能存在多种平方和的表示法。 要求你对4个数排序: 0 <= a <= b <= c <=d  并对所有的可能表示法按a,b,c,d 为联合主键升序排列,最后输出第一个表示法

2.需求分析

对4个数排序: 0 <= a <= b <= c<= d  并对所有的可能表示法按 a,b,c,d 为联合主键升序排列,最后输出第一个表示法

(1)    输入的形式和输入值的范围:输入一个整型数据 输入值范围为正int范围

(2)    输出的形式:a b b d

(3)    程序所能达到的功能:找出这个数等于的4个数平方和相加的数

(4)    测试数据:输入5 输出 0 0 1 2

3.概要设计

 

因为要求升序排序 所以一开始就设定 a<b<c<d即可这样就方便多了

用for循环寻找数字

只要输入的数等于a*a+b*b+c*c+d*d即可输出

4.用户说明

程序页面出现之后 直接输入一个整型数据

5.测试结果

6.附录

#include<stdio.h>

void main()

{

int a,b,c,d,n;

  while (scanf("%d",&n),n!=0)

    for(a=0;a<n;a++)

      for(b=a;b<n;b++)

        for(c=b;c<n;c++)

           for(d=c;d<n;d++)

             if(a*a+b*b+c*c+d*d==n)

            {

                printf("%d %d %d%d\n",a,b,c,d);return ;

            }

}


猜你喜欢

转载自blog.csdn.net/qq_41398448/article/details/80358125