PTA 7-151 找出三位水仙花数
题目描述:
本题要求编写程序,输出给定正整数M和N区间内的所有三位水仙花数。三位水仙花数,即其个位、十位、百位数字的立方和等于该数本身。
输入格式:
输入在一行中给出两个正整数 M 和 N(100≤M≤N≤999)。
输出格式:
顺序输出M和N区间内所有三位水仙花数,每一行输出一个数。若该区间内没有三位水仙花数,则无输出。
如果M或者N不符合题目的要求,则输出Invalid Value.
。
输入样例1:
100 400
输出样例1:
153
370
371
输入样例2:
500 600
输出样例2:
输入样例3:
990 101
输出样例3:
Invalid Value.
思路:
只需要知道一个结论即可:
在所有整数里面水仙花数有且仅有4个:153、370、371、407.
类似题目见:PTA 7-148 判断一个三位数是否为水仙花数
代码如下:
#include <iostream>
#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std;
int main()
{
int n, m;
cin >> n >> m;
if (n >= 100 && n <= m && m <= 999){
for (int i = n; i <= m; i++){
if (i == 153 || i == 370 || i == 371 || i == 407)
cout << i << endl;
}
}
else cout << "Invalid Value." << endl;
return 0;
}