毎日C言語練習 - 水仙の数を出力する

質問: すべての「水仙数」を出力してください。
解決策: いわゆる「水仙数」は 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 乗して出力します。

おすすめ

転載: blog.csdn.net/m0_58724783/article/details/131921433