注册 登录
编程论坛 C语言论坛

看一下这个循环的问题,怎么在循环里只输出一个no啊,急!

snowman666 发布于 2022-10-13 21:01, 1208 次点击
题目
完全数是这样一个整数,它加上100后是一个完全平方数,它加上268也是一个完全平方数。编程程序求出m,n之间所有完全数(包括m和n),其中n>m。
输入形式:输入一行,包括整数m和n。
输出形式:输出一行,输出m与n间的所有完全数,各数之间以空格分隔。若没有,则输出no。
样例输入:1 10000
样例输出: 21 261 1581
下面是我的代码
#include<stdio.h>
#include<math.h>
int main()
{
    int m,i,n;
    double k1,k2;
    scanf("%d%d",&m,&n);
    for(i=m;i<=n;i++)
    {
        k1=sqrt(i+100);
        k2=sqrt(i+268);   
        if((fabs(k1-(int)k1)<1e-6)&&(fabs(k2-(int)k2)<1e-6))
            printf(" %d",i);
    }
        
   
        return 0;
}
主体部分已经搞完了,就卡在那个输出一个no那个地方了,循环里怎么才能让它只输出一个no啊
救救孩子ba
2 回复
#2
rjsp2022-10-14 09:39
一般用浮点数函数都不是求确切解,一般用 <1e-6 都是外行的想当然。

x+100 = a*a; x+268=b*b ---> (b+a)(b-a) = 168 = 2*84 = 4*42 = 6*28 = 12*14 ---> x等于 -99 或 21 或 261 或 1581

程序代码:
#include <stdio.h>

int main( void )
{
    // 满足条件的所有数集合
    const int buf[4] = { -99, 21, 261, 1581 };

    // 输入
    int m, n;
    scanf( "%d%d", &m, &n );
   
    // 在 buf 中找到第一个 大于等于m 的数的位置 p
    size_t p;
    for( p=0; p!=4 && buf[p]<m; ++p );
    // 在 buf 中找到第一个 大于n     的数的位置 q
    size_t q;
    for( q=p; q!=4 && buf[q]<=n; ++q );

    // 输出
    if( p == q )
        puts( "no" );
    else
    {
        for( size_t i=p; i!=q; ++i )
            printf( "%d ", buf[i] );
    }
}
#3
snowman6662022-10-14 10:48
回复 2楼 rjsp
不好意思新手刚学C语言,只会这样弄。
1