java 基础练习 分解质因数 蓝桥杯1058
基础练习 分解质因数
Description
求出区间[a,b]中所有整数的质因数分解。
Input
输入描述:
输入两个整数a,b。
输入样例:
3 10
Output
输出描述:
每行输出一个数的分解,形如k=a1a2a3…(a1<=a2<=a3…,k也是从小到大的)(具体可看样例)
输出样例:
3=3
4=22
5=5
6=23
7=7
8=222
9=33
10=25
代码
import java.util.ArrayList;
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
int a = sc.nextInt();
int b =sc.nextInt();
ArrayList<Integer> prime = new ArrayList<Integer>();//存放可以使用的质因数
//初始化质因数(把a~b范围的质因数都找出来)
prime.add(2);
for (int i = 3; i <= b; i++) {
boolean flag = true;
for (int j = 2; j < Math.sqrt(i)+1; j++) {
if(i%j==0) {
flag = false;
}
}
if(flag==true) {
prime.add(i);
}
}
//找出每一个数的所有质因数
for (int i = a; i <= b; i++) {
String result = i+"=";
int temp = i;
while(temp!=1) {
for (int j = 0; j < prime.size(); j++) {
int p = prime.get(j);
if(temp%p==0) {
result = result + p+"*";
temp = temp/p;
break;
}
}
}
result = result.substring(0,result.length()-1);
System.out.println(result);
}
}
}