C语言经典例13-水仙花数
生活随笔
收集整理的這篇文章主要介紹了
C语言经典例13-水仙花数
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
目錄
- 1 題目
- 2 分析
- 3 實現
- 4 運行結果
1 題目
打印出所有的"水仙花數",所謂"水仙花數"是指一個三位數,其各位數字立方和等于該數 本身。例如:153153153是一個"水仙花數",因為153=13+53+33153=1^3+5^3+3^3153=13+53+33
2 分析
本題中限制數的范圍為三位數,那么使用for循環遍歷的時候范圍為100~999,然后用除法和取余操作將每個數的百位、十位、個位分離出來,然后將三個分離出來的數取三次方,再與原來的數比較,若相等,則就符合題意
3 實現
#include <stdio.h>int main() {for (int i = 100; i <= 999; i++) {int a = i % 10; // 分離出個位int b = i / 10 % 10; // 分離出十位int c = i / 100 % 10; // 分離出百位if (i == (a*a*a + b*b*b + c*c*c)) {printf("%d\n", i);}}return 0; }4 運行結果
153 370 371 407總結
以上是生活随笔為你收集整理的C语言经典例13-水仙花数的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: C语言经典例11-斐波那契数列
- 下一篇: C语言经典例14-将一个正整数分解质因数