3844.T-primes

Time Limit: 1s Memory Limit: 256MB

We know that prime numbers are positive integers that have exactly two distinct positive divisors. Similarly, we'll call a positive integer t Τ-prime, if t has exactly three distinct positive divisors.

You are given an array of n positive integers. For each of them determine whether it is Τ-prime or not.

Input Format(From the terminal/stdin)

The first line contains a single positive integer, n (1 \le n \le 105), showing how many numbers are in the array. The next line contains n space-separated integers xi (1 \le xi \le 1012).

Please, do not use the %lld specifier to read or write 64-bit integers in C++. It is advised to use the cin, cout streams or the %I64d specifier.

Output Format(To the terminal/stdout)

Print n lines: the i-th line should contain "YES" (without the quotes), if number xi is Τ-prime, and "NO" (without the quotes), if it isn't.

Sample Input

Copy
3
4 5 6
 \n
 · · \n

Sample Output

Copy
YES
NO
NO
   \n
  \n
  \n

Hints

The given test has three numbers. The first number 4 has exactly three divisors - 1, 2 and 4, thus the answer for this number is "YES". The second number 5 has two divisors (1 and 5), and the third number 6 has four divisors (1, 2, 3, 6), hence the answer for them is "NO".

Submit

请先 登录

© 2025 FAQs