Link:https://www.lydsy.com/JudgeOnline/problem.php?id=1407

Solution:

由于此题里n的范围很小,因此可以直接从小到大枚举m

那么问题转化为一个判定型问题:已知m,求是否会发生冲突

由于$O(m \cdot n^2)$的复杂度符合要求,枚举每一对(i,j)是否会发生冲突即可

可将问题转化为求同余式中最小的x

\[(step_i-step_j)x\equiv pos_j-pos_i(\mod m)\]

接下来就是数论里的套路了:

$ax \equiv b(\mod c)$可以转化为求$ax+cy=b$,我们可以用扩展欧几里得求出x,y值,同时顺便求出GCD。

设$k=c/gcd(a,c)$,$d=gcd(a,c)$

那么方程$ax \equiv b(\mod c)$的一个特解:$x_0=x \cdot (b/d)\mod c$。

(如果b不是d的倍数则无解)

并且它的d个解分别为:$x_i=(x_0+i*k)\mod c (i \in 0,1,2,.....d-1)$。

推导:

$$ax+cy=b$$

$$ax_0+cy_0=b$$

$$a(x-x_0) = c(y_0-y)$$

$$a/d(x-x_0) = c/d(y_0-y)$$

由于$$c/d\mid (x-x_0)$$

所以$$x = x_0+c/d*n$$

则方程ax≡b(mod c)的最小解为:$(x_0\mod k+k)\mod k$

Code:

#include <bits/stdc++.h>

using namespace std;
const int MAXN=; int n,c[MAXN],p[MAXN],l[MAXN]; int exgcd(int a,int b,int &x,int &y)
{
if(!b){x=;y=;return a;}
int ret=exgcd(b,a%b,x,y),t=x;
x=y;y=t-a/b*y;return ret;
} bool check(int m)
{
for(int i=;i<n;i++)
for(int j=i+;j<=n;j++)
{
int A=p[i]-p[j],B=c[j]-c[i],x,y,GCD=exgcd(A,m,x,y);
if(B%GCD) continue;
x=((x*B/GCD)%(m/GCD)+abs(m/GCD))%(m/GCD);
if(x<=min(l[i],l[j])) return false;
}
return true;
} int main()
{
cin >> n;int mx=;
for(int i=;i<=n;i++)
cin >> c[i] >> p[i] >> l[i],mx=max(mx,c[i]);//找到最小的初始值 for(int i=mx;i<=1e6;i++) if(check(i)) return cout << i,;
return ;
}

Review:

算是又了解一种套路了吧:

求 $ax \equiv b(\mod c)$ 中最小的x的公式:$(x_0\mod k+k)\mod k$  (先用exgcd算出$x_0$)

[BZOJ 1407] Savage的更多相关文章

  1. BZOJ 1407 Savage(拓展欧几里得)

    这题的时间复杂度真玄学... O(m*n^2).1e8也能过啊... 首先题目保证m<=1e6. 这启发我们枚举或者二分答案? 但是答案不满足单调性,考虑从小到大枚举m. 对于每一个m,枚举两个 ...

  2. BZOJ 1407: [Noi2002]Savage( 数论 )

    枚举答案, 然后O(N^2)枚举野人去判他们是否会在有生之年存在同山洞. 具体做法就是: 设第x年相遇, 则 Ci+x*Pi=Cj+x*Pj (mod M), 然后解同余方程. 复杂度应该是O(ans ...

  3. 【扩展欧几里得】Bzoj 1407: [Noi2002]Savage

    Description Input 第1行为一个整数N(1<=N<=15),即野人的数目.第2行到第N+1每行为三个整数Ci, Pi, Li (1<=Ci,Pi<=100, 0 ...

  4. 【BZOJ 1407】[Noi2002]Savage ExGCD

    我bitset+二分未遂后就来用ExGCD了,然而这道题的时间复杂度还真是玄学...... 我们枚举m然后对每一对用ExGCD判解,我们只要满足在最小的一方死亡之前无解就可以了,对于怎么用,就是ax+ ...

  5. bzoj 1407: [Noi2002]Savage

    Description 解题报告: 因为给定答案范围,暴力枚举时间,然后再两两枚举野人,判断是否有可能在某一年相遇,我们设这一年为\(x\),那么显然相交的条件是: \(x*(p[i]-p[j])+y ...

  6. 【bzoj 1407】【Noi2002】Savage

    Description Input 第1行为一个整数N(1<=N<=15),即野人的数目. 第2行到第N+1每行为三个整数Ci, Pi, Li表示每个野人所住的初始洞穴编号,每年走过的洞穴 ...

  7. bzoj 1407: [Noi2002]Savage【扩展欧几里得+中国剩余定理】

    首先答案不会很大,所以枚举答案m,于是把问题转为了判定: 关于如何判定: 首先题目中虽然没说但是数据是按照初始洞穴编号排的序,所以并不用自己重新再排 假设当前答案为m,相遇时间为x,野人i和j,那么可 ...

  8. bzoj [Noi2002]Savage 扩展欧几里得

    枚举m,n^2判断 对于野人i,j,(H[i]+x*S[i])%m==(H[j]+x*S[j])%m,且x<=O[i]&&x<=O[j],他们才有可能相遇 化简得:(S[i ...

  9. bzoj 1407 扩展欧几里德

    思路:枚举洞穴个数,用扩展欧几里德暴力判断没两个人的周期. #include<bits/stdc++.h> #define LL long long #define fi first #d ...

随机推荐

  1. 【BZOJ 3772】精神污染 主席树+欧拉序

    这道题的内存…………………真·精神污染……….. 这道题的思路很明了,我们就是要找每一个路径包含了多少其他路径那么就是找,有多少路径的左右端点都在这条路径上,对于每一条路径,我们随便选定一个端点作为第 ...

  2. Codeforces Round #348 (VK Cup 2016 Round 2, Div. 2 Edition) C

    C. Little Artem and Matrix time limit per test 2 seconds memory limit per test 256 megabytes input s ...

  3. POJ2289:Jamie's Contact Groups(二分+二分图多重匹配)

    Jamie's Contact Groups Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 125536/65536 K (Java/ ...

  4. bzoj 4624 农场种植 fft

    4624: 农场种植 Time Limit: 50 Sec  Memory Limit: 512 MBSubmit: 48  Solved: 31[Submit][Status][Discuss] D ...

  5. jquery、zepto冲突

    <script type="text/javascript" src="js/jquery.min.js"></script> < ...

  6. 100个Swift必备Tips(第二版)

    100个Swift必备Tips(第二版) 新年第一天,给大家一本电子书,希望新的一年里,步步高升. GitHub

  7. (转)tableview的索引设置

    .感觉tableview的索引条将表视图往左边挤了一点?别担心,只是颜色问题.只要如此设置即可 //索引条背景的颜色(清空颜色就不会感觉索引条将tableview往左边挤) [_tableView s ...

  8. React 使用 fetch 请求天气

    中国天气网(http://www.weather.com.cn)提供了查询天气的 API,通过传入城市 id, 可以获得当前城市的天气信息,API 相关信息如下: 规格  描述 主机地址 http:/ ...

  9. springMvc4+hibernate4+activiti5.15(Maven)

    首先创建activiti表 方式1.用代码创建 package createtable; import org.activiti.engine.ProcessEngineConfiguration; ...

  10. Spring表达式语言之SpEL

    •Spring 表达式语言(简称SpEL):是一个支持运行时查询和操作对象图的强大的表达式语言. •语法类似于 EL:SpEL 使用 #{…} 作为定界符,所有在大框号中的字符都将被认为是 SpEL ...