题解 HJ6| #质数因子#

质数因子

https://www.nowcoder.com/practice/196534628ca6490ebce2e336b47b3607

import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
        Scanner in = new Scanner(System.in);
        int a = in.nextInt();
        for (int i = 2; i <= Math.sqrt(a);) {
            if (a % i == 0) {
                System.out.print(i + " ");
                a = a / i;
            } else i++;
        }
        System.out.print(a);
    }
}

这题也是一样,要求是整数,就定义一个int类型

int a = in.nextInt();

之后求质数因子为了避免超时,有一个性质就是他的质数不会超过他的平方根

这样从2开始依次找能被整除的就行,依次输出质数+空格,这里要注意用print,这个不自带换行

for (int i = 2; i <= Math.sqrt(a);) {

if (a % i == 0) { //能整除就是质数,%是求余数,比如10%7=3,代表余数为3,余数为0即为整除

System.out.print(i + " ");

a = a / i;

} else i++;

}

System.out.print(a);//最后没有质数了就输出剩下的自己就可以了

}

#华为od题库#
华为OD笔试库讲解,JAVA版 文章被收录于专栏

随便发发而已

全部评论

相关推荐

我已成为0offer的糕手:别惯着,胆子都是练出来的,这里认怂了,那以后被裁应届被拖工资还敢抗争?
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务