PTA
输入两个3位的正整数m,n,输出[m,n]区间内所有的“水仙花数”。所谓“水仙花数”是指一个3位数,其各位数字的立方和等于该数本身。
输入格式:
测试数据由多组,处理到文件尾。每组测试输入两个3位的正整数m,n(100≤m<n≤999)。
输出格式:
对于每组测试,若[m,n]区间内没有水仙花数则输出none
,否则逐行输出区间内所有的水仙花数,每行输出的格式具体参看输出样例。
输入样例:
100 150
100 200
输出样例:
none
153=1*1*1+5*5*5+3*3*3
代码
#include<stdio.h>
int main()
{
int m,n,cout=0,a,b,c;
while(scanf("%d%d",&m,&n)!=EOF)
{
for (int i = m; i <= n; i++)
{
a = i / 100;
b = i / 10 % 10;
c = i % 10;
if (a * a * a + b * b * b + c * c * c == i)
{
printf("%d=%d*%d*%d+%d*%d*%d+%d*%d*%d\n", i, a, a, a, b, b, b, c, c, c);
cout++;
}
}
if (cout == 0)
{
printf("none\n");
}
}
}
在C语言中,当输入流或文件读取到文件结尾时,会返回特定的值来表示文件结束。这个特定的值就是EOF。具体来说,EOF的值是一个负数,通常为-1。