博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
CF 256C Furlo and Rublo and Game【博弈论,SG函数】
阅读量:6472 次
发布时间:2019-06-23

本文共 541 字,大约阅读时间需要 1 分钟。

暴力的求SG函数会超时,正解是先处理出10^6以内的SG值,对于更大的,开根号之后计算出。

小数据观察可以发现sg函数值成段出现,而且增长速度很快,因此可以计算出来每一段的范围,只需打表即可。

Nim游戏:

Nim和:L.Bouton给出了一个定理,状态(X1, X2, ..., Xn)为必败态当且仅当X1 xor X2 xor .... xor Xn = 0,xor是二进制的按位异或操作。

 

#include 
#include
using namespace std;typedef long long ll;ll x, a[] = {3, 15, 81, 6723, 50625, 2562991875LL};int sg[] = {0, 1, 2, 0, 3, 1, 2}, n, ans = 0;int main() { cin >> n; while (n--) { cin >> x; ans ^= sg[lower_bound(a, a+6, x)-a]; } cout << (ans ? "Furlo" : "Rublo") << endl; return 0;}

 

 

转载地址:http://expko.baihongyu.com/

你可能感兴趣的文章
java并发包分析之———Deque和LinkedBlockingDeque
查看>>
1. Two Sum - Easy - Leetcode解题报告
查看>>
SQLiteHelper
查看>>
多线程---同步函数的锁是this(转载)
查看>>
鱼C记事本V1.0(下)- 零基础入门学习Delphi28
查看>>
百练 2742 统计字符数 解题报告
查看>>
Ubuntu搜狗输入法候选词乱码
查看>>
js中回调函数写法
查看>>
React native android 最常见的10个问题
查看>>
数据结构和算法
查看>>
int a; int* a; int** a; int (*a)[]; int (*a)(int)
查看>>
.Net 项目代码风格要求
查看>>
java编码规范
查看>>
[pat]1045 Favorite Color Stripe
查看>>
Immutable学习及 React 中的实践
查看>>
【转】性能测试步骤
查看>>
OSI与TCP/IP各层的结构与功能,都有哪些协议
查看>>
Android实例-程序切换到后台及从后台切换到前台
查看>>
spring boot启动定时任务
查看>>
值类型和引用类型
查看>>