基础练习 特殊的数字

举报
陈言必行 发表于 2021/08/13 23:54:32 2021/08/13
【摘要】 问题描述 153是一个非常特殊的数,它等于它的每位数字的立方和,即153=1*1*1+5*5*5+3*3*3。编程求所有满足这种条件的三位十进制数。 输出格式 按从小到大的顺序输出满足条件的三位十进制数,每个数占一行。 注释:要实现其他位数的水仙花数,把下面a,b 初始值换成n位数即可 public class Main ...

问题描述
153是一个非常特殊的数,它等于它的每位数字的立方和,即153=1*1*1+5*5*5+3*3*3。编程求所有满足这种条件的三位十进制数。
输出格式
按从小到大的顺序输出满足条件的三位十进制数,每个数占一行。
注释:要实现其他位数的水仙花数,把下面a,b 初始值换成n位数即可


     
  1. public class Main {
  2. public static void main(String[] args) {
  3. int a=100;
  4. int b=1000;
  5. for(int i=a;i
  6. if(f(i)==1){
  7. System.out.println(i);
  8. }
  9. }
  10. }
  11. public static int f(int n){
  12. int t,temp,sum=0;
  13. int num=n;
  14. for(int i=0;i<3;i++){
  15. temp=num;
  16. sum+=temp*temp*temp;
  17. num=(num-temp)/10;
  18. }
  19. t=sum;
  20. if(t==n){
  21. return 1;
  22. }else{
  23. return -1;}
  24. }
  25. }



注:如果此代码,对您有帮助,请关注,会持续更新,,,如有需要C语言实现请留言,我看到会离开回复。

文章来源: czhenya.blog.csdn.net,作者:陈言必行,版权归原作者所有,如需转载,请联系作者。

原文链接:czhenya.blog.csdn.net/article/details/76091273

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。