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 装 pytorch 的时候出了好多问题,遇到这种情况怎么处理?
  • ¥20 IOS游览器某宝手机网页版自动立即购买JavaScript脚本
  • ¥15 手机接入宽带网线,如何释放宽带全部速度
  • ¥30 关于#r语言#的问题:如何对R语言中mfgarch包中构建的garch-midas模型进行样本内长期波动率预测和样本外长期波动率预测
  • ¥15 ETLCloud 处理json多层级问题
  • ¥15 matlab中使用gurobi时报错
  • ¥15 这个主板怎么能扩出一两个sata口
  • ¥15 不是,这到底错哪儿了😭
  • ¥15 2020长安杯与连接网探
  • ¥15 关于#matlab#的问题:在模糊控制器中选出线路信息,在simulink中根据线路信息生成速度时间目标曲线(初速度为20m/s,15秒后减为0的速度时间图像)我想问线路信息是什么