首先洛谷的题面十分的劝退(至少对我这个菜鸡来说是这样),我来解释一下(原来的英文题面):

有一个有若干个密码(每个密码都可以开箱子)的密码箱,密码是在$0$到$n-1$的数中的,且所有的密码都满足一个条件:如果$x$是密码,$y$也是密码($x$可能等于$y$),那么$(x+y)\%n$也是密码。现在有一个人在试密码,他试了$k$个数,前$k-1$个都是错的,第$k$个是对的。现在你要求这个密码箱最多有多少不同的密码。

显然如果$x$是一个密码,那么$ax(a∈N\&\&ax<n)$也都是密码。根据裴蜀定理,我们先让$num_k$和$n$取一个gcd得到$g$,然后把$g$分解因数得到$fac$个因数。从小到大枚举因数$f$,如果对于一个因数$f$前$k-1$个数都不能整除它,说明它符合题意,这个时候答案就是$\frac{n}{f}$,也就是取它的所有倍数。

然后我们发现这个玩意直接枚举来做的话理论上最差是$O(sqrt(n)k)$的,看起来根本过不去(实际上可以水过去),于是学习了一种筛法的解法。

我们换一种方法检查每个因数是否合法:首先标记$i=1->k-1$中所有的$gcd(num_i,num_k)$为不可取。接下来要用到一个性质:如果一个数$x$不可取,那么$x$所有的因数也一定都不可取(不要搞反了)。这样我们从大到小枚举一下$num_k$的所有因数$fac_i$,每次从小到大枚举$num_k$的质因数$pfac_j$,每次查看$num'=fac_i*pfac_j$(如果这个数存在的话),如果它不可取就将当前的因数标记为不可取,最后正着扫一遍就行了。复杂度$O(fac$ $log(n)log(fac))$(根本跑不满)

Update:讲了以后收到了很多疑问,筛答案那块没啥问题,主要是证明“显然如果$x$是一个密码,那么$ax(a∈N\&\&ax<n)$也都是密码” 这里(根本不显然=。=)和“根据裴蜀定理,我们先让$num_k$和$n$取一个gcd” 这里(为什么取gcd=。=?)。发现自己根本讲不清楚(完全暴露了数学鶸的本质233),看来还是要提高一个知识水平orz

现在更新一下详细证明:

1.为什么“如果$x$是一个密码,那么$ax(a∈N\&\&ax<n)$也都是密码”

这个问题有一个更“朴实”的问法:凭什么你可以用一个$x$和它的所有倍数表示出答案,而不是两个数组合呢?

(讲的时候极尬,完全不会讲TAT)

我们首先证明一个东西:如果$x$是密码,$y$是密码,那么$gcd(x,y)$也是密码

这个东西可以由裴蜀定理得出,问题是裴蜀定理说的是整数,我们要求必须是正整数

不过没关系,因为我们在模$n$剩余系下做,所以我们想$-ax$就等价于$+(kn-a)x(a,k∈N*)$

证明了这个,那么所有“两个数的组合”就都可以表示成它们的$gcd$了,于是问题解决

2.为什么“先让$num_k$和$n$取一个gcd”

暴力做应该不用取,但是筛的时候必须取

首先裴蜀定理告诉我们这样做了之后还是对的

那么为什么必须这样做呢?因为$num_k$中可能还有一个(相对于前$k-1$个数)独特的因数,然后你在排除的时候这个因数根本排不掉,你就把它当成答案了。。。

 #include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
const int N=;
long long p[N],fac[N],pfac[N];
long long n,k,g,tot,cnt;
bool una[N];
long long gcd(long long a,long long b)
{
return b?gcd(b,a%b):a;
}
void getf(long long maxx)
{
for(long long i=;i*i<=maxx;i++)
if(maxx%i==)
{
fac[++tot]=i;
if(i*i!=maxx)
fac[++tot]=maxx/i;
}
}
void getpf(long long maxx)
{
for(long long i=;i*i<=maxx;i++)
if(maxx%i==)
{
pfac[++cnt]=i;
while(maxx%i==) maxx/=i;
}
if(maxx!=) pfac[++cnt]=maxx;
}
int main()
{
scanf("%lld%lld",&n,&k);
for(int i=;i<=k;i++)
scanf("%lld",&p[i]);
if(!p[k]&&k==) printf("%lld",n),exit();
p[k]=gcd(p[k],n),getf(p[k]),getpf(p[k]);
sort(fac+,fac++tot);
for(int i=;i<k;i++)
una[lower_bound(fac+,fac++tot,gcd(p[i],p[k]))-fac]=true;
for(int i=tot;i;i--)
if(!una[i])
for(int j=;j<=cnt&&fac[i]*pfac[j]<=n;j++)
{
long long tmp=fac[i]*pfac[j];
int pos=lower_bound(fac+,fac++tot,tmp)-fac;
if(fac[pos]==tmp&&una[pos]) {una[i]=true; break;}
}
for(int i=;i<=tot;i++)
if(!una[i]) {printf("%lld",n/fac[i]); break;}
return ;
}

解题:POI 2011 Strongbox的更多相关文章

  1. 解题:POI 2011 Dynamite

    题面 从零开始的DP学习系列之叁 树形DP的基本(常见?)思路:先递归进儿子,然后边回溯边决策,设状态时常设$dp[x]$表示以$x$为根的子树中(具体分析算不算$x$这个点)的情况 显然的二分答案, ...

  2. 【BZOJ 2216】【POI 2011】Lightning Conductor

    http://www.lydsy.com/JudgeOnline/problem.php?id=2216 学习了一下决策单调性. 这道题决策单调性比较明显,不详细证了. 对于一个决策i,如果在i之前的 ...

  3. 【BZOJ 2212】【POI 2011】Tree Rotations

    http://www.lydsy.com/JudgeOnline/problem.php?id=2212 自下而上贪心. 需要用权值线段树来记录一个权值区间内的出现次数. 合并线段树时统计逆序对的信息 ...

  4. bzoj 2276 [ Poi 2011 ] Temperature —— 单调队列

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=2276 维护 l 递减的单调队列,队头的 l > 当前的 r 就出队,因为不能是连续一段 ...

  5. [ POI 2011 ] Party

    \(\\\) \(Description\) 给定一张 \(N\ (\ N\equiv 0\pmod{3}\ )\) 个节点,,\(M\)条边的图,并且保证该图存在一个大小至少为\(\frac{2}{ ...

  6. [ POI 2011 ] Dynamite

    \(\\\) \(Description\) 一棵\(N\)个节点的树,树上有\(M\)个节点是关键点,选出\(K\)个特殊点,使得所有关键点到特殊点的距离中最大的最小,输出最大值最小为多少. \(N ...

  7. 洛谷 P3515 [ POI 2011 ] Lightning Conductor —— 决策单调性DP

    题目:https://www.luogu.org/problemnew/show/P3515 决策单调性... 参考TJ:https://www.cnblogs.com/CQzhangyu/p/725 ...

  8. Solution -「POI 2011」「洛谷 P3527」MET-Meteors

    \(\mathcal{Description}\)   Link.   给定一个大小为 \(n\) 的环,每个结点有一个所属国家.\(k\) 次事件,每次对 \([l,r]\) 区间上的每个点点权加上 ...

  9. POI题解整合

    我也不知道为啥我就想把POI的题全都放到一篇blog里写完. POI 2005 SAM-Toy Cars 贪心,每次选下次出现最晚的. POI 2006 KRA-The Disks 箱子位置单调,所以 ...

随机推荐

  1. vmware安装androidx86 (FreeBSD) 系统图解

    有时候自己手机的一些方面限制的因素,我们需要在电脑上装一个“手机”,来完成我们想要做的事情. 安装步骤如下: 首先需要一个ISO系统镜像,下面地址可以提供大量镜像下载: https://zh.osdn ...

  2. mutt命令详解

    基础命令学习目录首页 linux命令——mutt的安装和使用[转] 首先介绍一下mutt这个软件,它是一款基于文字界面的邮件客户端,非常小巧,但功能强大,可以用它来读写,回复保存和删除你的邮件,能在l ...

  3. c# combobox向上展开

    1.问题情境:实际中的下拉框默认向下扩展,如果屏幕下方空间不足,会向上扩展. 向下扩展情况下,有时候会超出form窗体. 2.解决办法: 寻找相关属性无果. 退而求其次,重画item的框.发现Draw ...

  4. 用JAVA制作微型操作系统4月23日情况

    弄好了一个自认为十分精美的界面,但本想着昨天就在开始按钮上先套入控制jp222面板上的jb2标签上的时间更新,这按钮起到开始线程的作用(我认为按钮应该可以通过t.start()来触发线程,结果不知为什 ...

  5. 【动态规划】POJ-3616

    一.题目 Description Bessie is such a hard-working cow. In fact, she is so focused on maximizing her pro ...

  6. Request[""]接收的值有逗号(,)

    这是因为你的前台页面有连个标签的name值相等导致的.Request["name"]其实是通过name值或得标签的value值的. 所以一般情况下name值不要相等. 需要互斥的就 ...

  7. Daily target小队介绍(刘畅,陈杰,杨有存,唐祎琳,王晓哲,邵汝佳)

    一.团队介绍 1.团队构成: 2.队名: Daily target,我们的口号是Target your day! 3.团队项目描述: 我们计划写一个用于老师发布任务,学生接受任务的安卓app.教师安排 ...

  8. 团队作业4——第一次项目冲刺(Alpha版本)2017.11.14

    1.当天站立式会议照片 本次会议在5号公寓1楼召开,本次会议内容:①:熟悉每个人想做的模块.②:根据老师的要求将项目划分成一系列小任务.③:选择项目的开发模式:jsp+servlet+javabean ...

  9. 电梯调度系统(界面由C图形库编绘)

    电梯调度系统编程 1.编程题目 电梯调度. 2.结对编程组员 黄冠译,刘畅. 3.编程语言 C语言图形库. 4.题目要求: 5.代码运行及结果调试: ① 运行界面为C++图形库支持,开始运行的初始界面 ...

  10. 07_Java基础语法_第7天(练习)_讲义

    今日内容介绍 1.循环练习 2.数组方法练习 01奇数求和练习 * A: 奇数求和练习 * a: 题目分析 * 为了记录累加和的值,我们需要定义一个存储累加和的变量 * 我们要获取到1-100范围内的 ...