当前位置: 首页 > news >正文

题解:P14452 [ICPC 2025 Xian R] Follow the Penguins

(为什么还没有人写题解)

Solution

最暴力的方式肯定是直接按时间顺序模拟,但是会因为时间过长而超时,所以我们只在有效的时间点进行操作就好了。

有效的时间点自然是企鹅相遇的时候,那么就可以用一个 \(\mathtt{set}\) 来维护每只企鹅的预计相遇时间,用 \(\mathtt{vector}\) 数组来统计每只企鹅是哪些企鹅的目标。初始时只有和目标企鹅相向走的企鹅有预计时间,并且这个时间就是它最后的答案,而同向的预计时间先设为无穷大。每次取 \(\mathtt{set}\) 中时间最小的企鹅,计算出它相遇时停止的位置,得到以这只企鹅为目标的所有企鹅的预计时间,并在 \(\mathtt{set}\) 中更新这些企鹅的预计时间即可。

Code

#include<bits/stdc++.h>
using namespace std;
namespace io{(快读)}using namespace io;
const int N=5e5+5;
int n,now,t[N],a[N],w[N],nowt[N],ans[N];
vector<int>p[N];
set<pair<int,int>>S;
int main(){read(n);for(int i=1;i<=n;i++){read(t[i]);p[t[i]].push_back(i);}for(int i=1;i<=n;i++)a[i]=read()*2;//乘2避免小数for(int i=1;i<=n;i++)w[i]=(a[i]<=a[t[i]]);//每只企鹅移动方向for(int i=1;i<=n;i++){nowt[i]=((w[i]^w[t[i]])?abs(a[i]-a[t[i]])/2:(int)2e9);//预计时间S.insert(make_pair(nowt[i],i));}while(!S.empty()){int ti=S.begin()->first,x=S.begin()->second;S.erase(S.begin());now=ti;//当前时刻ans[x]=now;int posx=(w[x]?a[x]+now:a[x]-now);//停止位置for(int y:p[x]){auto iy=S.find(make_pair(nowt[y],y));if(iy==S.end())continue;S.erase(iy);int posy=(w[y]?a[y]+now:a[y]-now);//此时这只企鹅的位置nowt[y]=now+abs(posx-posy);S.insert(make_pair(nowt[y],y));//更新}}for(int i=1;i<=n;i++)writesp(ans[i]);return 0;
}
http://www.gsyq.cn/news/51573.html

相关文章:

  • 高安全性 PHP 2FA 开发指南:Authenticator 扫码验证实现方案
  • 20232417 2025-2026-1 《网络与系统攻防技术》实验五实验报告
  • 各组件证书配置文件yml
  • jmeter查看天气/快递操作
  • 详细介绍:MySQL——用户权限和管理
  • Django F对象完全指南:数据库层面的字段操作
  • Why cant Google appear in New York?
  • [AGC001E] BBQ Hard 分析
  • 哈希从入门到入土『给学弟学妹们讲课用的』
  • 20232303 2025-2026-1 《网络与系统攻防技术》实验五实验报告
  • .net 8+, 类库无法引用 WebApplication 的解决方案
  • 网络分析模型七
  • 2025-11-16
  • P14092 [ICPC 2023 Seoul R] M. S. I. S.
  • 【具身智能科普】表格分析核心概念、技术体系、应用场景落地、商业化等 - 指南
  • temperature、top_p、top_k
  • PyCharm gitee: Merge with strategy ort failed.
  • 获取数据,转换成JSON,返回到前端页面
  • 2025年11月副业平台推荐榜:五强生态模式深度解析
  • 完整教程:MySQL 8.0.29 及以上版本中 SSL/TLS 会话复用(Session Reuse)
  • 红队、蓝队与紫队:网络安全攻防演练的三大支柱
  • 2025年11月副业平台评价榜:零门槛生态对比助你安全增收
  • 调整电话交换机 3CX 对接微软 Teams 直接路由
  • Pycharm为什么会自动创建__pycache__
  • 山东大学 计算机图形学实验 二维网格剖分 Catmull-Clark算法
  • 什么是“组态路径”?
  • 深入探索剖析 JVM 的启动过程
  • noip8多校2
  • 2025年11月冷媒剂厂家榜单:五强技术参数与口碑对比评测
  • 工业级时序数据库选型指南:技巧架构与场景化实践