Codeforces Round #432 Div. 1 C. Arpa and a game with Mojtaba
首先容易想到,每种素数是独立的,相互sg就行了 
对于一种素数来说,按照的朴素的mex没法做。。。 
所以题解的简化就是数位化 
多个数同时含有的满参数因子pk由于在博弈中一同变化的,让他们等于相当于2k,那么这样就是一个数了
之后就是模拟,牛逼的思路
#include<iostream>
#include<map>
#include<iostream>
#include<cstring>
#include<cstdio>
#include<set>
#include<vector>
#include<queue>
#include<stack>
#include<algorithm>
using namespace std;
typedef long long ll;
const int N = 1e5+5;
#define MS(x,y) memset(x,y,sizeof(x))
#define MP(x, y) make_pair(x, y)
const int INF = 0x3f3f3f3f;
int prime[N];
int isprime[N]; int tot = 0;
int n;
map<int, int> mp;
map<int, int> dp;
map<int, int> ::iterator it;
int solve(int x){
    if(dp.find(x) != dp.end()) return dp[x];
    int mex[35];
    MS(mex, 0);
    for(int i = 0; x >> i; ++i) {
        int tt = solve( (x >> (i + 1)) | ( ((1<<i) - 1) & x ) );
        mex[tt] ++;
    }
    for(int i = 0; i < 35; ++i) {
        if(!mex[i]) {
            dp[x] = i;
            return i;
        }
    }
}
int main() {
    for(int i = 2; i < N; ++i) {
        if(isprime[i] == 0) {
            prime[++tot] = i;
            for(int j = 2*i; j < N; j += i) {
                isprime[j] ++;
            }
        }
    }
    while(~scanf("%d", &n)) {
        mp.clear();
        for(int i = 0; i < n; ++i) {
            int a; scanf("%d", &a);
            for(int j = 1; j <= tot; ++j) {
                if(a % prime[j] == 0) {
                    int cnt = 0;
                    while(a % prime[j] == 0) a /= prime[j], cnt ++;
                    mp[prime[j]] |= 1<<(cnt-1);
                    if(a == 1) break;
                }
            }
            if(a != 1) {
                mp[a] |= 1;
            }
        }
        int ans = 0;
        for(it = mp.begin(); it != mp.end(); ++it) {
            dp.clear();
            ans ^= solve(it -> second);
        }
        if(ans) printf("Mojtaba\n");
        else printf("Arpa\n");
    }
    return 0;
}
Codeforces Round #432 Div. 1 C. Arpa and a game with Mojtaba的更多相关文章
- Codeforces Codeforces Round #432 (Div. 2 D ) Arpa and a list of numbers
		D. Arpa and a list of numbers time limit per test 2 seconds memory limit per test 256 megabyte ... 
- Codeforces Round #432 (Div. 1) B. Arpa and a list of numbers
		qtmd的复习pat,老子不想看了,还不如练几道cf 这题首先可以很容易想到讨论最后的共因子为素数 这个素数太多了,1-1e6之间的素数 复杂度爆炸 所以使用了前缀和,对于每个素数k的每个小区间 (k ... 
- D. Arpa and a list of numbers Codeforces Round #432 (Div. 2, based on IndiaHacks Final Round 2017)
		http://codeforces.com/contest/851/problem/D 分区间操作 #include <cstdio> #include <cstdlib> # ... 
- 【前缀和】【枚举倍数】  Codeforces Round #432 (Div. 2, based on IndiaHacks Final Round 2017) D. Arpa and a list of numbers
		题意:给你n个数,一次操作可以选一个数delete,代价为x:或者选一个数+1,代价y.你可以进行这两种操作任意次,让你在最小的代价下,使得所有数的GCD不为1(如果全删光也视作合法). 我们从1到m ... 
- 【推导】Codeforces Round #432 (Div. 2, based on IndiaHacks Final Round 2017) B. Arpa and an exam about geometry
		题意:给你平面上3个不同的点A,B,C,问你能否通过找到一个旋转中心,使得平面绕该点旋转任意角度后,A到原先B的位置,B到原先C的位置. 只要A,B,C构成等腰三角形,且B为上顶点.那么其外接圆圆心即 ... 
- 【Codeforces Round #432 (Div. 2) A】 Arpa and a research in Mexican wave
		[链接]h在这里写链接 [题意] 在这里写题意 [题解] t<=k,输出t t>=n,输出k-t+n 其他情况都是k [错的次数] 0 [反思] 在这了写反思 [代码] /* */ #in ... 
- 【Codeforces Round #432 (Div. 2) B】Arpa and an exam about geometry
		[链接]h在这里写链接 [题意] 给你3个点A,B,C 问你能不能将纸绕着坐标轴上的一点旋转.使得A与B重合,B与C重合 [题解] 这3个点必须共圆. 则A,B,C不能为一条直线.否则无解. 共圆之后 ... 
- 【Codeforces Round #432 (Div. 1) B】Arpa and a list of numbers
		[链接]h在这里写链接 [题意] 定义bad list是一个非空的.最大公约数为1的序列.给定一个序列,有两种操作:花费x将一个元素删除.花费y将一个元素加1,问你将这个序列变为good list所需 ... 
- Codeforces Round #383 (Div. 2) C. Arpa's loud Owf and Mehrdad's evil plan —— DFS找环
		题目链接:http://codeforces.com/contest/742/problem/C C. Arpa's loud Owf and Mehrdad's evil plan time lim ... 
随机推荐
- SpringMVC源码情操陶冶-DispatcherServlet父类简析
			阅读源码有助于陶冶情操,本文对springmvc作个简单的向导 springmvc-web.xml配置 <servlet> <servlet-name>dispatch< ... 
- 无线渗透测试之wifi密码破解
			[声明]:本文仅供个人学习使用,请勿违法破解他人wifi 测试工具: 1.CDlinux启动盘:(请参照https://my.oschina.net/u/3112136/blog/800713) 2. ... 
- 洛谷 [P2765] 魔术球问题
			贪心做法 每次尽可能选择已经放过球的柱子 #include <iostream> #include <cstdio> #include <cstring> #inc ... 
- bzoj 4033: [HAOI2015]树上染色 [树形DP]
			4033: [HAOI2015]树上染色 我写的可是\(O(n^2)\)的树形背包! 注意j倒着枚举,而k要正着枚举,因为k可能从0开始,会使用自己更新一次 #include <iostream ... 
- SqlServer   varchar数据中类似于1.1.1.1这种值的排序方法
			select * from 表名order by Convert(int,left(列名,charindex('.',列名+'.')-1)) asc, 列名asc charindex('.',列名) ... 
- java递归
			package com.sun.test; import java.util.ArrayList; import java.util.List; /** * 递归 * */ public class ... 
- Math Jax开源数学编辑器的使用
			首先,这是一个开源免费,同时也可以支持扩展的软件. 使用API文档: 中文网站(http://mathjax-chinese-doc.readthedocs.io/en/latest/index.ht ... 
- C控制语句:分支和跳转
			小技巧:程序return前加个getchar();可以让程序停住.%%可以打印使printf()中打印出%号 #include<stdio.h>#define SPACE ''int ma ... 
- 五分钟了解Hash算法
			Hash算法详解 想象一下如果高级语言(Java,C++ ,C#)中如果没有实现类似List.Map等数据结构,企业级应用开发将是多么痛苦的事吧? Key-Value这种数据结构对于数据处理非常方便. ... 
- 【学习笔记】Struts2 类型转换
			为什么需要类型转换 在基于HTTP协议的Web应用中 客户端请求的所有内容(表单中提交的内容等)都以文本编码的方式传输到服务器端但服务器端的编程语言(如Java)有着丰富的数据类型 如 int boo ... 
