此题数据十分极限,需要优化,否则会超时。关于此题的不足:明明说的每堆石子数不超过100,我开一个105大小的数组想用哈希居然Runtime Error!!
后来看见有人说需要优化输入:
void in(int &a) {
char ch;
while((ch=getchar()) < '0' || ch > '9');
for(a = 0; ch >= '0' && ch <= '9'; ch = getchar())
a = a*10 + ch - '0';
}
好吧,我不知道为什这样输入整数会比scanf("%d", &a)更快?有知道的大神请透露一下。
AC代码
#include <cstdio>
int main() {
int T, n, x, res;
char ch;
scanf("%d", &T);
while(T--) {
scanf("%d", &n);
res = 0;
for(int i = 0; i < n; ++i) {
char ch;
while((ch=getchar()) <'0' || ch > '9');
for(x = 0; ch >= '0' && ch <= '9'; ch = getchar())
x = x*10 + ch - '0';
res ^= x;
}
if(res) printf("PIAOYI\n");
else printf("HRDV\n");
}
return 0;
}
如有不当之处欢迎指出!