#1509. Anon的疑问
Anon的疑问
说明
Anon作为海归高知,非常喜欢数学,有一天,她学到了\textit{费马平方和定理},该定理如下:
\textit{对于任意素数,存在两个正整数和,使得, 当且仅当或}
Anon第二天和Soyo分享了这个定理,Soyo却反过来询问Anon:"对于任意的数字,什么时候可以被分解为两个正整数的平方和?"
Anon经过一夜的苦思冥想,并借助GPT的帮助,终于知道了什么时候可以被分解平方和,次日Anon要面对Soyo的次提问,每次询问一个数,Anon只需要回答"Yes"或"No"表示该数是否可以被分解为平方和,而Anon觉得这个问题太简单了,就将这份任务交给你了。
正式描述如下:给出个询问,第次给出一个\bf{正整数},你需要确定是否存在两个\bf{正整数}使得,输出"Yes"或"No"表示是否可以被分解为\bf{两个正整数的平方和}。
请使用较快的输入输出方式。
例如:如果你使用的是cin/cout,请在main函数开头加入以下代码以加速输入输出:
ios::sync_with_stdio(nullptr); cin.tie(nullptr); cout.tie(nullptr);
输入格式
第一行包括一个正整数,表示询问的次数。
接下来的行,第行包括一个正整数,表示第次询问的数。
输出格式
输出行,第行输出Yes或No,表示是否能被分解为\bf{两个正整数的平方和}
样例
10
1
2
3
4
5
6
7
8
9
10
No
Yes
No
No
Yes
No
No
Yes
No
Yes
提示
对于样例,可以发现,,,,而其余剩余的都不能被分解为\bf{两个正整数的平方和}。
注意,要求是分解成正整数的平方和,因此不能被分解为
注: 表示除的余数为
相关
在下列比赛中: