BZOJ_5418_[Noi2018]屠龙勇士_exgcd+excrt

Description

www.lydsy.com/JudgeOnline/upload/noi2018day2.pdf


每次用哪吧剑显然用个set就搞定了。

对于每头龙,生命值ai,回血pi,剑的攻击力为atk,打的次数为ans。

显然有ans*atk-ai>=0&&pi|ans*atk-ai。

ans*atk+pi*y=ai (y<=0)。

要求y<=0的前提下ans尽量的小,是一个ax+by=n的形式,exgcd直接做。

然后得到n个方程,每个方程形如ans mod ai=bi。

ai不一定互质,直接上excrt。

感觉excrt一定程度上比crt还好理解。

大概就是个不断用exgcd合并的过程吧,自己想应该也能想出来。

代码:

#include <cstdio>
#include <cstring>
#include <algorithm>
#include <cstdlib>
#include <cmath>
#include <set>
using namespace std;
typedef long long ll;
#define N 100050
int n,m,da[N];
ll a[N],p[N],mods[N],q[N];
ll Abs(ll x) {return x>0?x:-x;}
multiset<ll>S;
ll ch(ll x,ll y,ll mod) {
ll re=0; for(;y;y>>=1ll,x=(x+x)%mod) if(y&1ll) re=(re+x)%mod; return re;
}
void exgcd(ll a,ll b,ll &x,ll &y,ll &p) {
if(!b) {p=a; x=1; y=0; return ;}
exgcd(b,a%b,y,x,p),y-=a/b*x;
}
ll gcd(ll x,ll y) {return y?gcd(y,x%y):x;}
void init() {
S.clear();
}
int find(ll x) {
multiset<ll>::iterator it;
it=S.upper_bound(x);
if(it!=S.begin()) {
it--;
}
int tmp=*it;
S.erase(it);
return tmp;
}
ll exCRT() {
int i;
ll M=mods[1],A=q[1],t,d,x,y;
for(i=1;i<=n;i++) {
exgcd(M,mods[i],x,y,d);
if((q[i]-A)%d) return -1;
t=mods[i]/d;
x=(x%t+t)%t;
x=ch(x,(((q[i]-A)/d)%t+t)%t,t);
A=M*x+A; M=M/d*mods[i]; A=A%M;
}
A=(A%M+M)%M;
return A;
}
void solve() {
init();
scanf("%d%d",&n,&m);
int i,x;
for(i=1;i<=n;i++) scanf("%lld",&a[i]);
for(i=1;i<=n;i++) scanf("%lld",&p[i]);
for(i=1;i<=n;i++) scanf("%d",&da[i]);
for(i=1;i<=m;i++) {
scanf("%d",&x); S.insert(x);
}
ll mx=0;
int flg=0;
for(i=1;i<=n;i++) {
ll D=find(a[i]),P=p[i],A=a[i],X,Y,d,td=D,tp=P,ta=A;
if(p[i]==1) {mx=max(mx,(a[i]+D-1)/D); flg=1; S.insert(da[i]); continue;}
exgcd(D,P,X,Y,d);mods[i]=P/d;
if(A%d) {puts("-1"); return ;}
D/=d; P/=d; A/=d;
D=Abs(D);
Y=(ch(Y,A,D)+D)%D;
if(Y>0) Y-=D;
X=(ta-tp*Y)/td;
q[i]=X;
S.insert(da[i]);
}
if(flg) printf("%lld\n",mx);
else printf("%lld\n",exCRT());
}
int main() {
// freopen("dragon.in","r",stdin);
// freopen("dragon.out","w",stdout);
int T;
scanf("%d",&T);
while(T--) solve();
}

BZOJ_5418_[Noi2018]屠龙勇士_exgcd+excrt的更多相关文章

  1. BZOJ5418 NOI2018屠龙勇士(excrt)

    显然multiset求出每次用哪把剑.注意到除了p=1的情况,其他数据都保证了ai<pi,于是先特判一下p=1.比较坑的是还可能存在ai=pi,稍微考虑一下. 剩下的部分即解bix≡ai(mod ...

  2. 「NOI2018」屠龙勇士(EXCRT)

    「NOI2018」屠龙勇士(EXCRT) 终于把传说中 \(NOI2018D2\) 的签到题写掉了... 开始我还没读懂题目...而且这题细节巨麻烦...(可能对我而言) 首先我们要转换一下,每次的 ...

  3. P4774 [NOI2018]屠龙勇士

    P4774 [NOI2018]屠龙勇士 先平衡树跑出打每条龙的atk t[] 然后每条龙有\(xt \equiv a[i](\text{mod }p[i])\) 就是\(xt+kp[i]=a[i]\) ...

  4. uoj396 [NOI2018]屠龙勇士

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

  5. BZOJ5418[Noi2018]屠龙勇士——exgcd+扩展CRT+set

    题目链接: [Noi2018]屠龙勇士 题目大意:有$n$条龙和初始$m$个武器,每个武器有一个攻击力$t_{i}$,每条龙有一个初始血量$a_{i}$和一个回复值$p_{i}$(即只要血量为负数就一 ...

  6. [洛谷P4774] [NOI2018]屠龙勇士

    洛谷题目链接:[NOI2018]屠龙勇士 因为markdown复制过来有点炸格式,所以看题目请戳上面. 题解: 因为杀死一条龙的条件是在攻击\(x\)次,龙恢复\(y\)次血量\((y\in N^{* ...

  7. 洛谷 P4774 [NOI2018] 屠龙勇士

    链接:P4774 前言: 交了18遍最后发现是多组数据没清空/ll 题意: 其实就是个扩中. 分析过程: 首先发现根据题目描述的选择剑的方式,每条龙对应的剑都是固定的,有查询前驱,后继(在该数不存在前 ...

  8. Luogu4774 NOI2018 屠龙勇士 ExCRT

    传送门 原来NOI也会出裸题啊-- 用multiset求出对付每一个BOSS使用的武器威力\(ATK_i\),可以得到\(m\)个式子\(ATK_ix \equiv a_i \mod p_i\) 看起 ...

  9. BZOJ5418:[NOI2018]屠龙勇士(exCRT,exgcd,set)

    Description Input Output Sample Input 23 33 5 74 6 107 3 91 9 10003 23 5 64 8 71 1 11 1 Sample Outpu ...

随机推荐

  1. Linux文件内容查阅

    直接查阅一个文件的内容:cat/tac/nl命令 cat (concatenate) # cat [-AbEnTv] 选项与參数: -A  :相当於 -vET 的整合选项.可列出一些特殊字符而不是空白 ...

  2. php自己编译安装后,再给这个编译安装的php版本添加拓展模块的处理办法。

    原文: https://www.cnblogs.com/zongyl/p/5924627.html 说明,给编译安装之后的php 添加pgsql 拓展成功. --------------------- ...

  3. 一起talk C栗子吧(第八十四回:C语言实例--使用信号进行进程间通信一)

    各位看官们,大家好,上一回中咱们说的是进程间通信的样例.这一回咱们说的样例是:使用信号进行进程间通信.闲话休提,言归正转. 让我们一起talk C栗子吧! 我们在上一回中提到过进程之间通信须要解决的三 ...

  4. redis cmd 使用样例

    Redis 命令參考 一 Redis介绍 Redis是一个开源的使用ANSI C语言编写.支持网络.可基于内存亦可持久化的日志型.Key-Value数据库,并提供多种语言的API.从2010年3月15 ...

  5. 数据库如何让自增id重置

    sql语句:truncate tablename;    会清空表的所有记录,并且使自增的id重置. 另外,navicat的截断表,就是这个功能. 它的清空表只会清空数据,不能使自增的id重置.

  6. Laravel建站01--开发环境部署

    内容导航 安装git 安装composer 安装Laravel 既然是开发环境,就需要源代码管理.这里使用git来管理. 一:部署开发环境之前安装git 在 Linux 上安装git 如果你想在 Li ...

  7. PHP中curl获取本机虚拟主机接口

    在PHP的curl代码中增加header可解决此问题. $header = array( "Host: 你的域名(不能包含http://)", "Accept: text ...

  8. Lombok简介

    Lombok简介 和其他语言相比,Java经常因为不必要的冗长被批评.Lombok提供了一系列注解用以在后台生成模板代码,将其从你的类中删除,从而有助于保持你的代码整洁.较少的模板意味着更简洁的代码, ...

  9. scikit-learn:4.2. Feature extraction(特征提取,不是特征选择)

    http://scikit-learn.org/stable/modules/feature_extraction.html 带病在网吧里. ..... 写.求支持. .. 1.首先澄清两个概念:特征 ...

  10. final、finally、三个关键字的区别

    一 final 如果一个类被声明为final,意味着它不能再派生出新的子类,不能作为父类被继承.因此一个类不能既被声明为 abstract的,又被声明为final的.将变量或方法声明为final,可以 ...