結果

問題 No.36 素数が嫌い!
ユーザー shin
提出日時 2022-05-18 09:35:24
言語 Java
(openjdk 23)
結果
AC  
実行時間 171 ms / 5,000 ms
コード長 1,104 bytes
コンパイル時間 4,188 ms
コンパイル使用メモリ 78,660 KB
実行使用メモリ 38,124 KB
最終ジャッジ日時 2024-09-16 10:16:27
合計ジャッジ時間 6,873 ms
ジャッジサーバーID
(参考情報)
judge3 / judge6
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 4
other AC * 26
権限があれば一括ダウンロードができます

ソースコード

diff #

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.ArrayList;
import java.util.TreeSet;

public class No36 {
	
	static TreeSet<Long> ts = new TreeSet<>();
	static TreeSet<Long> prime = new TreeSet<>();

	public static void main(String[] args) throws IOException{
		//素数が嫌い!
		long N = Long.parseLong(readStr()[0]);
		
		ts.add(1l);
		wari(N);
		
		System.out.println(ts.size() > prime.size() + 2 ? "YES" : "NO");

	}
	
	public static void wari(long a) {
		int sq = (int)Math.sqrt(a);
		ts.add(a);
		for(int i = 2;i <= Math.max(sq, 3);i++) {
			if(a % i == 0) {
				ts.add((long)i);
				prime.add((long)i);
				ts.add(a / i);
				wari(a / i);
				break;
			}
			if(i == sq) prime.add(a);
		}
	}
	
	public static String[] readStr() throws IOException{
		BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
		ArrayList<String> list = new ArrayList<>();

		do {
			list.add(br.readLine());
		}while(br.ready());

		br.close();

		String[] text = new String[list.size()];
		list.toArray(text);

		return text;

	}

}
0