C++中如何读取一个数的位数_求1000以内的水仙花数
點(diǎn)擊上方 藍(lán)字關(guān)注我們
大家好,我是阿湯哥。
看知乎上有朋友說還不明白怎么判斷水仙花數(shù),今天我們就來看看這個問題。(PS:“求1000以內(nèi)的水仙花數(shù)”這道題阿湯哥記憶猶新。到現(xiàn)在還記得這是我大一上學(xué)期期末考試的編程題。)
怎么求水仙花數(shù)?首先給出水仙花數(shù)定義。
水仙花數(shù)?定義
水仙花數(shù)(Narcissistic number)也被稱為超完全數(shù)字不變數(shù)(pluperfect digital invariant, PPDI)、自戀數(shù)、自冪數(shù)、阿姆斯壯數(shù)或阿姆斯特朗數(shù)(Armstrong number),水仙花數(shù)是指一個 3 位數(shù),它的每個位上的數(shù)字的 3次冪之和等于它本身(例如:1^3 + 5^3+ 3^3 = 153)。怎么判斷一個三位整數(shù)是不是水仙花數(shù)呢?我們根據(jù)它的定義來判斷,只要把個位數(shù)、十位數(shù)、百位數(shù)分別取出來,然后做立方和,判斷立方和是否等于這個數(shù)本身。
現(xiàn)在難點(diǎn)在于,怎么編程求一個三位數(shù)的個位數(shù)、十位數(shù)、百位數(shù)?
我們這樣來求:
假設(shè)一個三位數(shù)m=132,我們這樣來求它的個十百位數(shù):
求?個十百位數(shù)
1、求它的個位數(shù),用這個數(shù)對10求余數(shù),個位數(shù)a=132%10= 2
2、求它的十位數(shù),把這個數(shù)先除以10,商等于13,商13再對10求余數(shù),得到十位數(shù)b=13%10=3
3、求它的百位數(shù),把這個數(shù)對100求商,百位數(shù)c=132/100=1
我們來C語言編程實(shí)現(xiàn)“求1000以內(nèi)的水仙花數(shù)”,下面是完整代碼:
C語言代碼/**?*?Author:?阿湯哥
?*?微信公眾號:C語言修仙
?*?功能:?求1000以內(nèi)的水仙花數(shù)
?*/
#?include?
#?include?
/**
*?is_narcissus_number:?判斷一個整數(shù)是不是素數(shù)
*
*?@m:?待判斷是不是水仙花數(shù)的三位數(shù)
*
*?返回1:是素數(shù);返回0:不是素數(shù)
*/
int?is_narcissus_number(int?m){
????int?a,?b,?c;
????c?=?m?%?10;?????//個位數(shù)
????b?=?(m/10)?%?10;??//十位數(shù)
????a?=?m?/?100;????//百位數(shù)
????if?(m?==?(pow(a,?3)+?pow(b,?3)+?pow(c,?3)))
????????return?1;
????else
????????return?0;
}
int?main(){
????int?m,?a,?b,?c;
????//循環(huán)判斷100~999每個數(shù),如果是水仙花數(shù),那么把它打印出來
????for?(int?i?=?100;?i?1000;?i++)
????{
????????if?(is_narcissus_number(i)?==?1)
????????{
????????????printf("%d?是水仙花數(shù);\n",?i);
????????}
????}
????return?0;
}
運(yùn)行結(jié)果
往期推薦好文
★C語言編程工具的選擇★i++和++i有什么區(qū)別?★「建議收藏」C語言編程判斷回文數(shù)★看完你就明白:什么情況下該用int main(int argc, char *argv[])而不是int ????main(void)★C語言編程:打印一個圓形★福利:50本C語言電子書免費(fèi)送了!★C語言編程求解:1到1000之間所有的素數(shù)點(diǎn)個在看 你最好看
總結(jié)
以上是生活随笔為你收集整理的C++中如何读取一个数的位数_求1000以内的水仙花数的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: dropdownlist三级联动怎么实现
- 下一篇: coreavc filter在debug