鱼C论坛

 找回密码
 立即注册
查看: 2496|回复: 7

[已解决]输出水仙花数

[复制链接]
发表于 2021-10-25 21:10:07 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
输入一个正整数n(3<=n<=7),输出所有的n位水仙花数。水仙花数是指一个n位正整数,它的各位数字的n次幂之和等于它本身。例如153的各位数字的立方和是1^3+5^3+3^3=153.试着编写程序。
最佳答案
2021-10-25 22:11:02
本帖最后由 jackz007 于 2021-10-25 22:12 编辑

        原来是 C 语言问题
  1. #include <stdio.h>

  2. int main(void)
  3. {
  4.         int c , d , e , i , k , m , n , x                                            ;
  5.         scanf("%d" , & n)                                                            ;
  6.         if(n >= 3 && n <= 7) {
  7.                 for(d = i = 1 ; i < n ; i ++) d *= 10                                ;
  8.                 for(x = d ; x < d * 10 ; x ++) {
  9.                         for(m = 0 , k = x , e = d ; e ; k %= e , e /= 10) {
  10.                                 for(c = 1 , i = 0 ; i < n ; i ++) c *= k / e         ;
  11.                                 m += c                                               ;
  12.                         }
  13.                         if(x == m) printf("%d\n" , x)                                ;
  14.                 }
  15.         }
  16. }
复制代码

        编译、运行实况:
  1. D:\00.Excise\C>g++ -o x x.c

  2. D:\00.Excise\C>x
  3. 3
  4. 153
  5. 370
  6. 371
  7. 407

  8. D:\00.Excise\C>x
  9. 5
  10. 54748
  11. 92727
  12. 93084

  13. D:\00.Excise\C>
复制代码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2021-10-25 21:16:27 | 显示全部楼层
本帖最后由 傻眼貓咪 于 2021-10-25 21:35 编辑
  1. #include <stdio.h>
  2. #include <stdbool.h>
  3. #include <math.h>

  4. bool isNarcissistic(long long m, int n){
  5.     long long a = m, b, sum = 0;
  6.     while(a > 0){
  7.         b = a%10;
  8.         sum += pow(b, n);
  9.         a /= 10;
  10.     }
  11.     return sum == m ? true : false;
  12. }

  13. int main(){
  14.     int n; // (3 <= n <= 7)
  15.     scanf("%d", &n);
  16.     for(long long i = pow(10, (n-1)); i < pow(10, n); i++){
  17.         if(isNarcissistic(i, n)){
  18.             printf("%lld\n", i);
  19.         }
  20.     }
  21.     return 0;
  22. }
复制代码
  1. 4
  2. 1634
  3. 8208
  4. 9474
复制代码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-10-25 21:33:40 | 显示全部楼层
本帖最后由 jackz007 于 2021-10-25 21:35 编辑
  1. n = int(input())
  2. if 3 <= n <= 7:
  3.     d = 10 ** (n - 1)
  4.     for x in range(d , d * 10) :
  5.         m , e , k = 0 , d , x      
  6.         while e:            
  7.             m += (k // e) ** n
  8.             k %= e
  9.             e //= 10
  10.         if m == x:
  11.             print(x)
复制代码

运行实况:
  1. D:\00.Excise\Python>python x.py
  2. 3
  3. 153
  4. 370
  5. 371
  6. 407

  7. D:\00.Excise\Python>python x.py
  8. 5
  9. 54748
  10. 92727
  11. 93084

  12. D:\00.Excise\Python>
复制代码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-10-25 21:53:31 | 显示全部楼层

浅谈水仙花数题目
https://fishc.com.cn/thread-192863-1-1.html
(出处: 鱼C论坛)
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-10-25 22:06:40 | 显示全部楼层
柿子饼同学 发表于 2021-10-25 21:53
浅谈水仙花数题目
https://fishc.com.cn/thread-192863-1-1.html
(出处: 鱼C论坛)

        有何指教?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-10-25 22:11:02 | 显示全部楼层    本楼为最佳答案   
本帖最后由 jackz007 于 2021-10-25 22:12 编辑

        原来是 C 语言问题
  1. #include <stdio.h>

  2. int main(void)
  3. {
  4.         int c , d , e , i , k , m , n , x                                            ;
  5.         scanf("%d" , & n)                                                            ;
  6.         if(n >= 3 && n <= 7) {
  7.                 for(d = i = 1 ; i < n ; i ++) d *= 10                                ;
  8.                 for(x = d ; x < d * 10 ; x ++) {
  9.                         for(m = 0 , k = x , e = d ; e ; k %= e , e /= 10) {
  10.                                 for(c = 1 , i = 0 ; i < n ; i ++) c *= k / e         ;
  11.                                 m += c                                               ;
  12.                         }
  13.                         if(x == m) printf("%d\n" , x)                                ;
  14.                 }
  15.         }
  16. }
复制代码

        编译、运行实况:
  1. D:\00.Excise\C>g++ -o x x.c

  2. D:\00.Excise\C>x
  3. 3
  4. 153
  5. 370
  6. 371
  7. 407

  8. D:\00.Excise\C>x
  9. 5
  10. 54748
  11. 92727
  12. 93084

  13. D:\00.Excise\C>
复制代码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2021-10-25 23:11:02 | 显示全部楼层
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-10-25 23:12:35 | 显示全部楼层


不不不 , 就是跟个帖
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-5-13 16:49

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表