「NOI2018」屠龙勇士(EXCRT)

终于把传说中 \(NOI2018D2\) 的签到题写掉了。。。

开始我还没读懂题目。。。而且这题细节巨麻烦。。。(可能对我而言)

首先我们要转换一下,每次的 \(atk[i]\) 都可以用 \(multiset\) 找。

我们发现题目求的是 \(atk*x\equiv a_i(\text{mod}\ p_i)\),所以我们做一遍 \(exgcd\),求出同余方程。

然后就可以愉快的 \(EXCRT\) 了~

不过发现一次要把龙的血量清零,所以一定要减到负数。我们在求 \(atk[i]\) 的时候顺便求一下最大值就行了。

当然,中间无论什么时候无解都输出 \(-1\)

\(Code\ Below:\)

#include <bits/stdc++.h>
#define ll long long
using namespace std;
const int maxn=100000+10;
int n,m,flag;ll a[maxn],p[maxn],b[maxn],c[maxn],A[maxn],B[maxn],Max;
multiset<ll> s;
multiset<ll>::iterator it; void exgcd(ll a,ll b,ll &g,ll &x,ll &y){
if(b==0){
g=a;x=1;y=0;
return;
}
exgcd(b,a%b,g,y,x);
y-=(a/b)*x;
} inline ll mul(ll a,ll b,ll mod){
ll ret=0;b=(b%mod+mod)%mod;
for(;b;b>>=1,a=(a+a)%mod)
if(b&1) ret=(ret+a)%mod;
return ret;
} inline void merge(ll &a1,ll &b1,ll a2,ll b2){
ll d=a2-a1,g,x,y;
exgcd(b1,b2,g,x,y);
if(d%g==0){
x=(mul(x,d/g,b2/g)+(b2/g))%(b2/g);
a1=x*b1+a1;b1=b1/g*b2;
}
else flag=1;
} inline ll excrt(ll *a,ll *b){
ll a1,b1,a2,b2;
a1=a[1];b1=b[1];
for(int i=2;i<=n;i++){
a2=a[i];b2=b[i];
merge(a1,b1,a2,b2);
if(flag) return -1;
}
if(a1>=Max) return a1;
return a1+((Max-a1)/b1+((Max-a1)%b1?1:0))*b1;
} int main()
{
int T;
scanf("%d",&T);
while(T--){
scanf("%d%d",&n,&m);flag=Max=0;s.clear();
ll d,g,x,y;
for(int i=1;i<=n;i++) scanf("%lld",&a[i]);
for(int i=1;i<=n;i++) scanf("%lld",&p[i]);
for(int i=1;i<=n;i++) scanf("%lld",&b[i]);
for(int i=1;i<=m;i++){
scanf("%lld",&x);
s.insert(x);
}
for(int i=1;i<=n;i++){
it=s.upper_bound(a[i]);
if(it!=s.begin()) it--;
c[i]=*it;s.erase(s.find(*it));s.insert(b[i]);
Max=max(Max,a[i]/c[i]+(a[i]%c[i]?1:0));
}
//atk * x = a_1 (mod p_1)
for(int i=1;i<=n;i++){
d=a[i];exgcd(c[i],p[i],g,x,y);
if(d%g){flag=1;break;}
x=(mul(x,d/g,p[i]/g)+(p[i]/g))%(p[i]/g);
A[i]=x;B[i]=p[i]/g;
}
if(flag) printf("-1\n");
else printf("%lld\n",excrt(A,B));
}
return 0;
}

「NOI2018」屠龙勇士(EXCRT)的更多相关文章

  1. 「NOI2018」屠龙勇士

    「NOI2018」屠龙勇士 题目描述 小\(D\)最近在网上发现了一款小游戏.游戏的规则如下: 游戏的目标是按照编号\(1-n\)顺序杀掉\(n\) 条巨龙,每条巨龙拥有一个初始的生命 值ai .同时 ...

  2. POJ1061 青蛙的约会 和 LOJ2721 「NOI2018」屠龙勇士

    青蛙的约会 Language:Default 青蛙的约会 Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 133470 Accep ...

  3. 「NOI2018」屠龙勇士 解题报告

    「NOI2018」屠龙勇士 首先对于每个龙用哪个剑砍,我们可以用set随便模拟一下得到. 然后求出拿这个剑砍这条龙的答案 \[ atk_ix-p_iy=a_i \] 其中\(atk_i\)是砍第\(i ...

  4. LOJ #2721. 「NOI2018」屠龙勇士(set + exgcd)

    题意 LOJ #2721. 「NOI2018」屠龙勇士 题解 首先假设每条龙都可以打死,每次拿到的剑攻击力为 \(ATK\) . 这个需要支持每次插入一个数,查找比一个 \(\le\) 数最大的数(或 ...

  5. loj#2721. 「NOI2018」屠龙勇士

    题目链接 loj#2721. 「NOI2018」屠龙勇士 题解 首先可以列出线性方程组 方程组转化为在模p意义下的同余方程 因为不保证pp 互素,考虑扩展中国剩余定理合并 方程组是带系数的,我们要做的 ...

  6. 「NOI2018」屠龙勇士(CRT)

    /* 首先杀每条龙用到的刀是能够确定的, 然后我们便得到了许多形如 ai - x * atki | pi的方程 而且限制了x的最小值 那么exgcd解出来就好了 之后就是扩展crt合并了 因为全T调了 ...

  7. LOJ 2721 「NOI2018」屠龙勇士——扩展中国剩余定理

    题目:https://loj.ac/problem/2721 1.注意别一输入 p[ i ] 就 a[ i ] %= p[ i ] ,因为在 multiset 里找的时候还需要真实值. 2.注意用 m ...

  8. 「NOI2018」你的名字

    「NOI2018」你的名字 题目描述 小A 被选为了\(ION2018\) 的出题人,他精心准备了一道质量十分高的题目,且已经 把除了题目命名以外的工作都做好了. 由于\(ION\) 已经举办了很多届 ...

  9. loj#2718. 「NOI2018」归程

    题目链接 loj#2718. 「NOI2018」归程 题解 按照高度做克鲁斯卡尔重构树 那么对于询问倍增找到当前点能到达的高度最小可行点,该点的子树就是能到达的联通快,维护子树中到1节点的最短距离 s ...

随机推荐

  1. tp5文件上传展示

    //接收文件 $file = request()->file('image'); //将文件移动到框架应用根目录/public/uploads/ 目录下 $info = $file->mo ...

  2. df命令详解

    1.简介: df命令作用是列出文件系统的整体磁盘空间使用情况.可以用来查看磁盘已被使用多少空间和还剩余多少空间. df命令显示系统中包含每个文件名参数的磁盘使用情况,如果没有文件名参数,则显示所有当前 ...

  3. 真机调试adb:wait for device 解决方案

    1.adb logcat 命令的时候,cmd总是提示adb server did't ACK.       分析一下,明显adb server没有开启成功,服务启动失败一般都是端口绑定失败,所以我们只 ...

  4. 牛客练习赛42(A,B)

    A:链接:https://ac.nowcoder.com/acm/contest/393/A 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 262144K,其他语言524288K 6 ...

  5. ToolBar+Drawable实现一个好用的侧滑栏(侧边栏)和工具栏

    先参考下ToolBar的使用和DrawableLayout的使用: 1.主界面布局,主要结构包含一个ToolBar和一个DrawableLayout,DrawableLayout里面有左侧边栏布局和主 ...

  6. python note 06 编码方式

    1.有如下值li= [11,22,33,44,55,66,77,88,99,90],将所有大于 66 的值保存至字典的第一个key中,将小于 66 的值保存至第二个key的值中.即: {'k1': 大 ...

  7. [leetcode]84. Largest Rectangle in Histogram直方图中的最大矩形

    Given n non-negative integers representing the histogram's bar height where the width of each bar is ...

  8. init.d目录下的文件定义

    init.d目录下存放的一些脚本一般是linux系统设定的一些服务的启动脚本. 系统在安装时装了好多服务,这里面就有很多对应的脚本. 执行这些脚本可以用来启动,停止,重启这些服务. 1.这些链接文件前 ...

  9. Linux系统minicom命令详解

    minicom 功能说明:调制解调器通信程序 语 法:minicom [-8lmMostz][-a<on或0ff>][-c<on或off>][-C<取文件>][-d ...

  10. PHP请求ws出现的问题

    在SOAPUI中的请求如下: <soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/&qu ...