找出三位水仙花数
7-1 找出三位水仙花数
分数 10
作者 颜晖
单位 浙大城市学院
本题要求编写程序,输出给定正整数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.
解题思路
- 循环区间中的每一个数字
- 将每一个数字的个位,十位和百位数字进行拆分。
- 将个位,十位,百位数字分别求三次方并相加求和与原数字x进行判断。
- 对输入区间数字判断其合法性。
#include <stdio.h>
#include <math.h>
int get_unit(int x)
{
if (x < 100 || x > 999)
{
return 0;
}
return x % 10;
}
int get_hundred(int x)
{
if (x < 100 || x > 999)
{
return 0;
}
return x / 100;
}
int get_ten(int x)
{
if (x < 100 || x > 999)
{
return 0;
}
return (x - (x % 10)) / 10 % 10;
}
int main()
{
int m, n, ge, shi, bai, res;
scanf("%d %d", &m, &n);
if (100 <= m && m <= n && n <= 999)
{
res = 0;
}
else
{
printf("Invalid Value.");
return 0;
}
for (size_t i = m; i <= n; i++)
{
ge = get_unit(i);
shi = get_ten(i);
bai = get_hundred(i);
res = pow(ge, 3) + pow(shi, 3) + pow(bai, 3);
if (res == i)
{
printf("%d\n", i);
}
}
return 0;
}

浙公网安备 33010602011771号