链接在这:http://bak.vjudge.net/contest/132442#overview

  A题,给出a,b和n,初始的集合中有a和b,每次都可以从集合中选择不同的两个,相加或者相减,得到一个新的数,如果在1~n内的话就放入集合中,并算一次操作,谁先不能操作(所有新数已经存在于集合内的话就不能进行操作)者输。问谁会赢。

  可以得到的数字为k*gcd(a,b),那么只要算出在1~n的范围内存在多少个这样的数字,判断一下奇偶性即可。

  

  B题,给出n个字符串,问最大的满足条件的字符串的位置,条件为,在它前面的字符串中至少存在一个字符串不是它的子串。那么方法是我们判断第 i 个字符串的时候,找出前面的不是别人子串的那些字符串,来判断是不是这个字符串的子串,如果不是,那么更新答案,如果是(那么是前面这个字符串子串的字符串肯定也都是 i 的子串,而我们要找的是不是 i 子串的字符串),那么前面那个字符串给一个标记,表示它也是别人的子串了,那么后面就不用再管它了。显然复杂度是O(n^2+n*lenth)。

  

  C题,因为一个集合内互相到达的距离t都是相等的,那么我们可以新建一个点,这个集合内的点到新点的距离都为0,而新点到集合内的点的距离都是t,借助这个辅助点,我们就可以将条件转化了。然后我们使用dijkstra算法找出从1开始的最短路和从n开始的最短路即可。

  D,每个青蛙可以遍历的石头其实是k*gcd(a[i],m),但是很显然会有重复,因此我们用容斥做。具体方法比较奥义,见代码吧(手动模拟一下以后就比较好理解了):

 #include <stdio.h>
#include <algorithm>
#include <string.h>
using namespace std;
const int N = +;
typedef long long ll; int n,m;
int a[N];
int cnt,p[];
int vis[],num[];
// vis表示这个因子应该被使用的次数,num表示这个因子已经使用过的次数 int main()
{
int T;scanf("%d",&T);
for(int kase=;kase<=T;kase++)
{
memset(vis,,sizeof(vis));
memset(num,,sizeof(num));
scanf("%d%d",&n,&m);
for(int i=;i<=n;i++) scanf("%d",a+i);
cnt = ;
for(int i=;1LL*i*i<=(ll)m;i++)
{
if(m%i==)
{
p[++cnt] = i;
if(1LL*i*i != (ll)m) p[++cnt] = m/i;
}
}
sort(p+,p++cnt);
for(int i=;i<=n;i++)
{
int g = __gcd(a[i],m);
for(int j=;j<=cnt;j++)
{
if(p[j] % g == ) vis[j] = ;
}
} vis[cnt] = ; // 最后一个数是不能跳的
ll ans = ;
for(int i=;i<=cnt;i++)
{
if(vis[i] != num[i])
{
ans += 1LL * (vis[i]-num[i]) * m * (m/p[i] - ) / ;
int t = vis[i] - num[i];
for(int j=i;j<=cnt;j++)
{
if(p[j]%p[i] == ) num[j] += t;
}
}
}
printf("Case #%d: %I64d\n",kase,ans);
}
}

2015ACM/ICPC亚洲区沈阳站 部分题解的更多相关文章

  1. 2015ACM/ICPC亚洲区沈阳站 Pagodas

    Pagodas Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)Total Sub ...

  2. 2015ACM/ICPC亚洲区沈阳站 B-Bazinga

    Bazinga Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)Total Sub ...

  3. hdu 5510 Bazinga (kmp+dfs剪枝) 2015ACM/ICPC亚洲区沈阳站-重现赛(感谢东北大学)

    废话: 这道题很是花了我一番功夫.首先,我不会kmp算法,还专门学了一下这个算法.其次,即使会用kmp,但是如果暴力枚举的话,还是毫无疑问会爆掉.因此在dfs的基础上加上两次剪枝解决了这道题. 题意: ...

  4. 2015ACM/ICPC亚洲区沈阳站-重现赛 M - Meeting (特殊建边,最短路)

    题意:有\(n\)个点,\(m\)个集合,集合\(E_i\)中的点都与集合中的其它点有一条边权为\(t_i\)的边,现在问第\(1\)个点和第\(n\)个点到某个点的路径最短,输出最短路径和目标点,如 ...

  5. 2015ACM/ICPC亚洲区沈阳站-重现赛 B - Bazinga (KMP)

    题意:给你\(n\)个字符串,\(s_1,s_2,...,s_n\),对于\(i(1\le i\le n)\),找到最大的\(i\),并且满足\(s_j(1\le j<i)\)不是\(s_i\) ...

  6. 2015ACM/ICPC亚洲区沈阳站-重现赛 D - Pagodas

    题意:有\(n\)个数,开始给你两个数\(a\)和\(b\),每次找一个没出现过的数\(i\),要求满足\(i=j+k\)或\(i=j-k\),当某个人没有数可以选的时候判他输,问谁赢. 题解:对于\ ...

  7. 2015ACM/ICPC亚洲区沈阳站

    5510 Bazinga 题意:给出n个字符串,求满足条件的最大下标值或层数 条件:该字符串之前存在不是 它的子串 的字符串 求解si是不是sj的子串,可以用kmp算法之类的. strstr是黑科技, ...

  8. 2015ACM/ICPC亚洲区沈阳站 Solution

    A - Pattern String 留坑. B - Bazinga 题意:找一个最大的i,使得前i - 1个字符串中至少不是它的子串 思路:暴力找,如果有一个串已经符合条件,就不用往上更新 #inc ...

  9. 2015ACM/ICPC亚洲区沈阳站重现赛-HDU5512-Pagodas-gcd

    n pagodas were standing erect in Hong Jue Si between the Niushou Mountain and the Yuntai Mountain, l ...

随机推荐

  1. 反射获取config实体类属性并赋值

    /// <summary> /// 将实体类存入config /// </summary> /// <param name="enity">&l ...

  2. 服务端相关知识学习(二)之Zookeeper可以干什么

    Zookeeper主要可以干哪些事情 配置管理,名字服务,提供分布式同步以及集群管理.那这些服务又到底是什么呢?我们为什么需要这样的服务?我们又为什么要使用Zookeeper来实现呢,使用Zookee ...

  3. centos配置vsftpd服务2

    ftp搭建 一.搭建前提a.ssh服务已经开启,b.防火墙关闭,c.连网1.查看ssh和防火墙的状态 service sshd status service iptables status 2.开启s ...

  4. 客户端注册Cannot execute request on any known server解决

    在对eureka注册中心服务端添加安全验证后,新版本springcloud出现一个问题就是,在客户端注册到服务中心时报了一个错:Cannot execute request on any known ...

  5. 使用docker搭建OpenResty开发环境

    Dockerfile文件: FROM centos:latest RUN yum install -y pcre-devel openssl-devel gcc curl wget perl make ...

  6. SQL Server 2005 实现数据库同步备份 过程--结果---分析

    数据库复制:   简单来说,数据库复制就是由两台服务器,主服务器和备份服务器,主服务器修改后,备份服务器自动修改. 复制的模式有两种:推送模式和请求模式,推送模式是主服务器修改后,自动发给备份服务器, ...

  7. 第五章·Logstash深入-日志收集

    1.Logstash收集单个日志到文件中 file模块收集日志 不难理解,我们的日志通常都是在日志文件中存储的,所以,当我们在使用INPUT插件时,收集日志,需要使用file模块,从文件中读取日志的内 ...

  8. XML基础介绍【二】

    XML基础介绍[二] 1.schema约束dtd语法: <!ELEMENT 元素名称 约束>schema符合xml的语法,xml语句.一个xml中可以有多个schema,多个schema使 ...

  9. 内核模式构造-Mutex构造(RecursiveAutoResetEvent)

    internal sealed class RecursiveAutoResetEvent : IDisposable { private AutoResetEvent m_lock = new Au ...

  10. “联邦对抗技术大赛”9月开战 微众银行呼唤开发者共同“AI创新”

    “联邦对抗技术大赛”9月开战  微众银行呼唤开发者共同“AI创新”   从<第五元素>中的智能系统到<超体>中的信息操控,在科幻电影中人工智能已经发展到了极致.而在现实中,目前 ...