nyoj585 取石子(六) Nimm博弈

来源:互联网 发布:淘宝联盟用店铺红包 编辑:程序博客网 时间:2024/05/21 10:06

           此题数据十分极限,需要优化,否则会超时。关于此题的不足:明明说的每堆石子数不超过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;} 

如有不当之处欢迎指出!

0 0