【ShawnZhang】带你看蓝桥杯—— 算法提高 质因数2

  算法提高 质因数2  
时间限制:1.0s   内存限制:256.0MB
   
  将一个正整数N(1
输入格式
  一行,一个正整数
输出格式
  两行,第一行为用空格分开的质因数
  第二行为质因数的个数
样例输入
66
样例输出
2 3 113
样例输入
90
样例输出
2 3 3 5
4
样例输入
37
样例输出
37
1


先贴代码

import java.util.Scanner;

public class ADV181 {

	public static void main(String[] args) {
		// TODO Auto-generated method stub
		Scanner in=new Scanner(System.in);
		int n=in.nextInt();
		in.close();
		int i=2;
		int[] a=new int[10000];
		int index=0;
		while(n>1){
			while(n%i==0){
				a[index]=i;
				n/=i;
				index++;
			}
			i++;
		}
		index=0;
		while(a[index]!=0){
			System.out.print(a[index]+" ");
			index++;
		}
		System.out.println();
		System.out.println(index);
		
	}

}

这道题还是挺简单的,主要就是公因数的算法,以上算法还是挺简单的

你可能感兴趣的:(蓝桥杯Java算法训练)