找出三位水仙花数

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.

解题思路

  1. 循环区间中的每一个数字
  2. 将每一个数字的个位,十位和百位数字进行拆分。
  3. 将个位,十位,百位数字分别求三次方并相加求和与原数字x进行判断。
  4. 对输入区间数字判断其合法性。
#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;
}
posted @ 2022-10-08 14:42  蠢蛋快跑  阅读(582)  评论(0)    收藏  举报