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 .同时每条巨龙拥有恢复能 ...
随机推荐
- kali 安装 shodan
声明! 学习视频来自B站up主 泷羽sec 有兴趣的师傅可以关注一下,如涉及侵权马上删除文章,笔记只是方便各位师傅的学习和探讨,文章所提到的网站以及内容,只做学习交流,其他均与本人以及泷羽sec团队无 ...
- ZCMU-1038
其实感觉不太难,读懂题意就行,我一开始没有仔细去读感觉就很懵.其题目意思就是一段字符串含有数字和'<'或者'>',一开始从左开始遍历,遇到'>'这类东西换方向,如果有多次遇到就删之前 ...
- Javascript 常用封装(二)
1.字符串占位宽度 计算占位宽度:字符串的占位宽度除了涉及到具体的字符串内容,还与字体大小有关,可以将其放入Dom中来获取实际占位宽度 //计算字符串的占位宽度 function getTextWid ...
- LeetCode题集-5 - 最长回文子串之马拉车(二)
书接上回,我们今天继续来聊聊最长回文子串的马拉车解法. 题目:给你一个字符串 s,找到 s 中最长的回文子串. 01.中心扩展法优化-合并奇偶处理 俗话说没有最好只有更好,看着O(n^2)的时间复杂度 ...
- 微软中文输入法带来的一点小坑,导致arcgispro输入中文异常
有同事反映,在Pro中新建要素类时,没办法设定名称为"新建",会自己变成不完整的拼音. 查看了一下,确有此事. 在相同的界面里还有其他输入框,却没有这种情况. 研究了一下,发现是输 ...
- Oracle.DataAccess.Client.OracleException: 提供程序与此版本的 Oracle 客户机不兼容
背景:进行程序部署,客户机上原有oracle客户端的版本为2.113.1.0(以下简称113),而数据库.开发机和其他客户机上均采用的2.112.1.0(以下简称112)客户端,所以进行了替换. 卸载 ...
- 基于.NET8+Vue3开发的权限管理&个人博客系统
前言 今天大姚给大家分享一个基于.NET8+Vue3开发的权限管理&个人博客系统:Easy.Admin. 项目介绍 Easy.Admin是一个基于.NET8+Vue3+TypeScript开发 ...
- 再次探讨 WinForms 多线程开发
再次探讨 WinForms 多线程开发 WinForms 已经开源,您现在可以在 GitHub 上查看 WinForm 源代码. 正好有人又讨论到在 WinFroms 环境下的多线程开发,这里就再整理 ...
- django模型层(orm相关知识点)
目录 一.模型层之前期准备 模型层的了解 模型 模型层的前置知识点 二.ORM常用关键字 三.ORM执行SQL语句 四.神奇的双下划线查询 五.ORM外键字段的创建 复习MySQL外键关系 外键字段的 ...
- Qt/C++地址转坐标/坐标转地址/逆地址解析/支持百度高德腾讯和天地图
一.前言说明 地址和经纬度坐标转换的功能必须在线使用,一般用在导航需求上,比如用户输入起点地址和终点地址,查询路线后,显示对应的路线,而实际上各大地图厂家默认支持的是给定经纬度坐标来查询(百度地图支持 ...