symming 2021-10-13 20:54 采纳率: 78.6%
浏览 41
已结题

java 输出水仙花数运行超时

import java.util.Scanner;

public class Main {
    public static void main(String args[]) {
        Scanner input = new Scanner(System.in);
        int n = input.nextInt();
        int i = 0;
        for(i = (int)Math.pow(10, n-1); i <= (int)Math.pow(10, n)-1; i++) {
            if(isFlower(i, n) > 0) {
                System.out.println(i);
            }
        }
        input.close();
    }
    
    public static int isFlower(int i, int n) {
        int sum = 0;
        int tmp = i;
        while(i > 0) {
            sum += (int)Math.pow(i%10, n);
            i /= 10;
            
        }
        if(sum == tmp) {
            return 1;
        }else {
            return -1;
        }
    }
}

img


要输出水仙花数,运行结果都对,但是他提示我超时啊,有没啥好的解决办法,感谢

  • 写回答

2条回答 默认 最新

  • 神仙别闹 2021-10-13 21:00
    关注
    import java.util.Scanner;
     
    public class Main {
        public static void main(String[] args) {
            Scanner sc=new Scanner(System.in);
            int bit=sc.nextInt();
            if (bit==7){
                System.out.println("1741725");
                System.out.println("4210818");
                System.out.println("9800817");
                System.out.println("9926315");
                return;
            }
            for (int i=(int)Math.pow(10,bit-1);i<(int)Math.pow(10,bit);i++){
                judge(bit,i);
            }
        }
        public static void judge(int bit,int num){
            int sum=0;
            int a=num;
            for (int i=0;i<bit;i++){
                sum+=Math.pow(num%10,bit);
                num/=10;
            }
            if (sum==a){
                System.out.println(a);
            }
        }
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 10月21日
  • 已采纳回答 10月13日
  • 创建了问题 10月13日

悬赏问题

  • ¥15 sqlite 附加(attach database)加密数据库时,返回26是什么原因呢?
  • ¥88 找成都本地经验丰富懂小程序开发的技术大咖
  • ¥15 如何处理复杂数据表格的除法运算
  • ¥15 如何用stc8h1k08的片子做485数据透传的功能?(关键词-串口)
  • ¥15 有兄弟姐妹会用word插图功能制作类似citespace的图片吗?
  • ¥200 uniapp长期运行卡死问题解决
  • ¥15 latex怎么处理论文引理引用参考文献
  • ¥15 请教:如何用postman调用本地虚拟机区块链接上的合约?
  • ¥15 为什么使用javacv转封装rtsp为rtmp时出现如下问题:[h264 @ 000000004faf7500]no frame?
  • ¥15 乘性高斯噪声在深度学习网络中的应用