質問: すべての「水仙数」を出力してください。
解決策: いわゆる「水仙数」は 3 桁の数字を指し、各桁の 3 乗の和はその数字自体に等しくなります。
たとえば、153 = 1 * 1 * 1 + 5 * 5 * 5 +3 * 3 * 3 であるため、153 は水仙の番号です。
#define _CRT_SECURE_NO_WARNINGS 1
#include <stdio.h>
// 编写了个方法(function)
int lifang(int a)
{
return a * a * a;
}
int main() {
// 初始化
int a = 0;
int b = 0;
int c = 0;
// 100 - 1000 中的水仙花数
for (int i = 100; i < 1000; i++) { // 因为 三位数 是从 100 - 999 然后每次循环 i+1;
a = i / 100; // 取个位 ;如果 i = 153,i = 1.53,因为是整数,i = 1;
b = i % 100 / 10; // 取十位;如果 i = 153,i取模然后除,i = 153 % 100 = 53, i = 53 /10 =5.3 = 5;
c = i % 10; // 取百位 ;如果 i = 153,i取模,i = 153 % 10 = 3;
// 调用 lifang这个方法,把分别得到的 a,b,c分别放到里面,进行立方然后相加最后等于它本身
if (lifang(a) + lifang(b) + lifang(c) == i) {
printf("%d\n", i); // 如果等于它本身 就打印,不等于它就不打印;
}
}
return 0;
}
実行結果は次のとおりです。
問題解決のアイデア: 3 乗は 1 桁の 3 乗であり、3 桁を分割し、分割後にそのたびに値を代入し、各桁を 3 乗して出力します。