C語言趣味編程之水仙花數(shù)
題目描述
求出所有的水仙花數(shù)
分析
百度百科:水仙花數(shù)(Narcissistic number)也被稱為超完全數(shù)字不變數(shù)(pluperfect digital invariant, PPDI)、自戀數(shù)、自冪數(shù)、阿姆斯壯數(shù)或阿姆斯特朗數(shù)(Armstrong number),水仙花數(shù)是指一個 3 位數(shù),它的每個位上的數(shù)字的 3次冪之和等于它本身。例如:13 + 53+ 33 = 153。
判斷一個數(shù)是否為水仙花數(shù),可以先將該數(shù)的所有位都取出并存入數(shù)組,最后代入水仙花數(shù)的公式,如果滿足水仙花條件,該數(shù)即為水仙花數(shù)。
代碼實(shí)現(xiàn)
#include <stdio.h>
#define INTEGER_MAXIMUM 999 //數(shù)字范圍,最大值
#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已求出所有水仙花數(shù)\n");
return 0;
}
/**
* @brief 判斷是否為水仙花數(shù)
* @return 1:是水仙花數(shù);0:不是水仙花數(shù)
*/
int if_narcissistic_number(int num)
{
/* 如果不是3位數(shù) */
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;
}
運(yùn)行結(jié)果

相關(guān)文章
VC外部符號錯誤_main,_WinMain@16,__beginthreadex解決方法
這篇文章主要介紹了VC外部符號錯誤_main,_WinMain@16,__beginthreadex解決方法,實(shí)例分析了比較典型的錯誤及對應(yīng)的解決方法,需要的朋友可以參考下2015-05-05
Objective-C中使用STL標(biāo)準(zhǔn)庫Queue隊(duì)列的方法詳解
這篇文章主要介紹了Objective-C中使用STL標(biāo)準(zhǔn)庫Queue隊(duì)列的方法,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友參考下吧2024-01-01
解析VC中創(chuàng)建DLL,導(dǎo)出全局變量,函數(shù)和類的深入分析
本篇文章是對VC中創(chuàng)建DLL,導(dǎo)出全局變量,函數(shù)和類進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-05-05
C語言巧用二分查找實(shí)現(xiàn)猜數(shù)游戲
二分查找也稱折半查找(Binary?Search),它是一種效率較高的查找方法。但是,折半查找要求線性表必須采用順序存儲結(jié)構(gòu),而且表中元素按關(guān)鍵字有序排列,本篇文章教你用二分查找編寫猜數(shù)字游戲2022-02-02
關(guān)于C++靜態(tài)數(shù)據(jù)成員的實(shí)現(xiàn)講解
今天小編就為大家分享一篇關(guān)于關(guān)于C++靜態(tài)數(shù)據(jù)成員的實(shí)現(xiàn)講解,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧2018-12-12

