P4774 [NOI2018] 屠龙勇士 题解
题解
思路
由题目可知,一条龙被攻击 \(x\) 次并回复若干次后生命值恰好为 \(0\) 则死亡,可以得出如下式子:
\]
可推出,
\]
需要求 \(ATK_i\) 在模 \(p_i\) 意义下的逆元。
我们自然会想到使用扩展欧几里得算法,但题中数据并不能保证 \(\gcd(ATK_i,p_i)\)。因此,需要将 \(ATK_i\)、\(a_i\) 和 \(p_i\) 同时除以 \(\gcd(ATK_i,p_i)\)。
此时,如果 \(\gcd(ATK_i,p_i) \nmid a_i\),那么此方程无解,方程组也无解。
于是我们得到了如下式子:
\]
看起来很吓人,但写起来一点也不吓人。
于是我们得到了一个标准的 exCRT 问题。直接套用求解即可。
注意,攻击次数 \(x\) 应当保证每一条龙打 \(x\) 下后生命值都不大于 \(0\)。不然回复不了。
实现
注意多测。
首先需要求出每条龙的 \(ATK\)。类似于求 \(a_i\) 在数组中的前驱。
可以用平衡树实现,但是 注意到标签里并没有平衡树 笔者平衡树写挂了 这样做太麻烦,于是我们使用multiset
。
在对每一个方程进行转化的过程中和 exCRT 中判断无解。
代码
\(\gcd\) 和 exgcd 就不放了,注意开__int128
。
对每一个方程进行转化:
bool calc()
{
for(int i=1;i<=n;i++)
{
long long gcd1=gcd(atk[i],p[i]);
if(a[i]%gcd1)
return 0;
atk[i]/=gcd1,p[i]/=gcd1,a[i]/=gcd1;
__int128 x,y;
exgcd(atk[i],p[i],x,y);
b[i]=a[i]*x%p[i];
}
return 1;
}
exCRT:
long long exCRT()
{
for(int i=2;i<=n;i++)
{
__int128 x,y;
__int128 gcd1=exgcd(p[1],p[i],x,y);
if((b[i]-b[1])%gcd1) return -1;
x*=(b[i]-b[1])/gcd1;
x%=p[i]/gcd1;
b[1]+=p[1]*x;
p[1]*=p[i]/gcd1;
}
b[1]=(b[1]%p[1]+p[1])%p[1];
return b[1];
}
主体部分:
注意多测
ms.clear(); //multiset
scanf("%d%d",&n,&m);
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",&rew[i]);
while(m--)
{
long long tmp;
scanf("%lld",&tmp);
ms.insert(tmp);
}
for(int i=1;i<=n;i++)
{
auto pos=ms.upper_bound(a[i]);
if(pos!=ms.begin())
pos--;
atk[i]=*pos;
ms.erase(pos);
ms.insert(rew[i]);
}
long long mtimes=0;
for(int i=1;i<=n;i++)
mtimes=std::max(mtimes,(long long)((a[i]+atk[i]-1)/atk[i])); //std::max()比较不了__int128
if(!calc())
printf("-1\n");
else
{
long long ans=exCRT();
if(ans==-1)
{
printf("-1\n");
continue;
}
long long tmp1=mtimes/p[1];
ans+=p[1]*tmp1;
if(ans<mti)
ans+=p[1];
printf("%lld\n",ans);
}
\]
P4774 [NOI2018] 屠龙勇士 题解的更多相关文章
- P4774 [NOI2018]屠龙勇士
P4774 [NOI2018]屠龙勇士 先平衡树跑出打每条龙的atk t[] 然后每条龙有\(xt \equiv a[i](\text{mod }p[i])\) 就是\(xt+kp[i]=a[i]\) ...
- [洛谷P4774] [NOI2018]屠龙勇士
洛谷题目链接:[NOI2018]屠龙勇士 因为markdown复制过来有点炸格式,所以看题目请戳上面. 题解: 因为杀死一条龙的条件是在攻击\(x\)次,龙恢复\(y\)次血量\((y\in N^{* ...
- 洛谷 P4774 [NOI2018] 屠龙勇士
链接:P4774 前言: 交了18遍最后发现是多组数据没清空/ll 题意: 其实就是个扩中. 分析过程: 首先发现根据题目描述的选择剑的方式,每条龙对应的剑都是固定的,有查询前驱,后继(在该数不存在前 ...
- 洛谷 P4774 / loj 2721 [NOI2018] 屠龙勇士 题解【同余】【exgcd】【CRT】
推导过程存在漏洞+exCRT板子没打熟于是期望得分÷实际得分=∞? 题目描述 小 D 最近在网上发现了一款小游戏.游戏的规则如下: 游戏的目标是按照编号 \(1\sim n\) 顺序杀掉 \(n\ ...
- luogu P4774 [NOI2018]屠龙勇士
传送门 这题真的是送温暖啊qwq,而且最重要的是yyb巨佬在Day2前几天正好学了crt,还写了博客 然而我都没仔细看,结果我就同步赛打铁了QAQ 我们可以先根据题意,使用set维护,求出每次的攻击力 ...
- (伪)再扩展中国剩余定理(洛谷P4774 [NOI2018]屠龙勇士)(中国剩余定理,扩展欧几里德,multiset)
前言 我们熟知的中国剩余定理,在使用条件上其实是很苛刻的,要求模线性方程组\(x\equiv c(\mod m)\)的模数两两互质. 于是就有了扩展中国剩余定理,其实现方法大概是通过扩展欧几里德把两个 ...
- 洛谷P4774 [NOI2018]屠龙勇士 [扩欧,中国剩余定理]
传送门 思路 首先可以发现打每条龙的攻击值显然是可以提前算出来的,拿multiset模拟一下即可. 一般情况 可以搞出这么一些式子: \[ atk_i\times x=a_i(\text{mod}\ ...
- BZOJ5418[Noi2018]屠龙勇士——exgcd+扩展CRT+set
题目链接: [Noi2018]屠龙勇士 题目大意:有$n$条龙和初始$m$个武器,每个武器有一个攻击力$t_{i}$,每条龙有一个初始血量$a_{i}$和一个回复值$p_{i}$(即只要血量为负数就一 ...
- BZOJ_5418_[Noi2018]屠龙勇士_exgcd+excrt
BZOJ_5418_[Noi2018]屠龙勇士_exgcd+excrt Description www.lydsy.com/JudgeOnline/upload/noi2018day2.pdf 每次用 ...
- uoj396 [NOI2018]屠龙勇士
[NOI2018]屠龙勇士 描述 小 D 最近在网上发现了一款小游戏.游戏的规则如下: 游戏的目标是按照编号 1∼n 顺序杀掉 n 条巨龙,每条巨龙拥有一个初始的生命值 ai .同时每条巨龙拥有恢复能 ...
随机推荐
- 设计模式【3.2】-- JDK动态代理源码分析有多香?
前面文章有说到代理模式:http://aphysia.cn/archives/dynamicagentdesignpattern 那么回顾一下,代理模式怎么来的?假设有个需求: 在系统中所有的 con ...
- (系列十三)Vue3+Echarts搭建超好看的系统面板
说明 该文章是属于OverallAuth2.0系列文章,每周更新一篇该系列文章(从0到1完成系统开发). 该系统文章,我会尽量说的非常详细,做到不管新手.老手都能看懂. 说明:OverallAuth2 ...
- Javascript 常用封装(二)
1.字符串占位宽度 计算占位宽度:字符串的占位宽度除了涉及到具体的字符串内容,还与字体大小有关,可以将其放入Dom中来获取实际占位宽度 //计算字符串的占位宽度 function getTextWid ...
- Echarts 颜色管理
1.Echarts的颜色设计 Echarts的颜色的设置分为两种:色盘和具体颜色 色盘适合做全局设置,因为他里面有多个颜色,通俗的说色盘就是颜色预设值列表,色盘统一使用color属性进行配置. 而具体 ...
- vue3 父子组件传值
父传子组件 <template> <div> <!-- 通过自定义属性传递值 --> <Subassembly :value="doc"/ ...
- VTK 平面裁剪
有些时候需要显示零件内部情况,所有会对零件显示进行平面裁剪,这里用到了vtkPlane和vtkClipPolyData. vtkPlane是定义一个平面,vtkClipPolyData使用vtkPla ...
- Gitee三方登录_Python (超详细)
第三方登录是一种常见的身份验证机制,允许用户使用他们在其他平台(如社交媒体.电子邮件服务或开发平台)的账号来登录你的应用或网站,而不需要创建新的用户名和密码.这种方式不仅简化了用户的登录过程,还提高了 ...
- Xshell无法连接22端口问题解决办法汇总
Xshell软件在进行远程连接过程中,会出现端口连接报错的问题,提示:"该IP地址的22端口连接失败",这是怎么回事?今天小编就xshell软件无法连接22端口的问题,整理相关情形 ...
- baomidou的dynamic-datasource读写分离实现和加入AOP根据方法名选择库
文档 https://gitee.com/baomidou/dynamic-datasource-spring-boot-starter/wikis/pages maven <depende ...
- Qt开发经验小技巧226-230
qtc开发工具内置了不少的函数,可以很方便的进行一些判断和处理. //最小版本要求 !minQtVersion(5, 15, 2) { message("Cannot build Qt In ...