C語言趣味編程之水仙花數
題目描述
求出所有的水仙花數
分析
百度百科:水仙花數(Narcissistic number)也被稱為超完全數字不變數(pluperfect digital invariant, PPDI)、自戀數、自冪數、阿姆斯壯數或阿姆斯特朗數(Armstrong number),水仙花數是指一個 3 位數,它的每個位上的數字的 3次冪之和等於它本身。例如:13 + 53+ 33 = 153。
判斷一個數是否為水仙花數,可以先將該數的所有位都取出並存入數組,最後代入水仙花數的公式,如果滿足水仙花條件,該數即為水仙花數。
代碼實現
#include <stdio.h> #define INTEGER_MAXIMUM 999 //數字范圍,最大值 #define INTEGER_MINIMUM 100 //最小值 int if_narcissistic_number(int num); int main() { int i = 0; for(i = INTEGER_MINIMUM; i <= INTEGER_MAXIMUM; i++) { if(if_narcissistic_number(i)) { printf("%d ", i); } } printf("\n已求出所有水仙花數\n"); return 0; } /** * @brief 判斷是否為水仙花數 * @return 1:是水仙花數;0:不是水仙花數 */ int if_narcissistic_number(int num) { /* 如果不是3位數 */ if(num < 100 || num > 999) return 0; int hundreds = num / 100; //百位 int tens = num / 10 % 10; //十位 int ones = num % 10; //個位 if(num == hundreds * hundreds *hundreds +\ tens * tens * tens +\ ones * ones * ones) return 1; return 0; }
運行結果
推薦閱讀:
- C++實現水仙花數判斷實例
- python實現水仙花數實例講解
- C語言中#define定義的標識符和宏實例代碼
- C語言實現打印楊輝三角的方法詳細(三種方法)
- C語言中#define在多行宏定義出錯的原因及分析