[NOI2019]弹跳
时间:2019-10-17
本文章向大家介绍[NOI2019]弹跳,主要包括[NOI2019]弹跳使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
[NOI2019]弹跳
传送门
Solution
先看一档部分分:\(h=1\),这个时候显然可以线段树优化连边。
树套树
那么这启示我们可以用一些奇技淫巧来优化连边,考虑每一个弹跳装置可以到达的是个矩形,那么不难想到树套树是吧,所以直接这样子连边即可。
发现空间限制\(125MB\),开不下怎么办?边走边做即可,因为\(dijkstra\)的一些特性发现每一个点最多进队一次,所以直接删除即可。
KD-Tree
因为是平面信息,所以我们也可以用\(KD-Tree\)维护,你每一次找到矩形然后把这里面的点暴力抠出来加进优先队列然后删除,跑\(dijkstra\)即可。还是利用了\(dijkstra\)的特性!
Code
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<math.h>
#include<algorithm>
#include<queue>
#include<set>
#include<map>
#include<iostream>
using namespace std;
#define ll long long
#define REP(a,b,c) for(int a=b;a<=c;a++)
#define re register
#define file(a) freopen(a".in","r",stdin);freopen(a".out","w",stdout)
inline int gi(){
int f=1,sum=0;char ch=getchar();
while(ch>'9' || ch<'0'){if(ch=='-')f=-1;ch=getchar();}
while(ch>='0' && ch<='9'){sum=(sum<<3)+(sum<<1)+ch-'0';ch=getchar();}
return f*sum;
}
const int N=150010;
int n,m,w,h,y[N],t[N],L[N],R[N],D[N],U[N],dis[N],vis[N];
vector<int>vec[N];
typedef pair<int,int> pii;
#define mp make_pair
priority_queue<pii,vector<pii>,greater<pii> >q;
multiset<pii>se[N<<2];
void modify(int o,int l,int r,int pos,int id){
se[o].insert(mp(y[id],id));
if(l==r)return;
int mid=(l+r)>>1;
if(pos<=mid)modify(o<<1,l,mid,pos,id);
else modify(o<<1|1,mid+1,r,pos,id);
}
void Del(int o,int l,int r,int u,int d){
if(l>R[u] || r<L[u])return;
if(L[u]<=l && r<=R[u]){
multiset<pii>::iterator it=se[o].lower_bound(mp(D[u],0)),tmp;
while(it!=se[o].end() && (*it).first<=U[u]){
int now=(*it).second;
if(!vis[now]){
vis[now]=1;dis[now]=d;
for(int v:vec[now])
q.push(mp(d+t[v],v));
}
tmp=it;it++;se[o].erase(tmp);
}
return;
}
int mid=(l+r)>>1;
Del(o<<1,l,mid,u,d);Del(o<<1|1,mid+1,r,u,d);
}
int main(){
n=gi();m=gi();w=gi();h=gi();memset(dis,63,sizeof(dis));dis[1]=0;
for(int i=1;i<=n;i++){
int x=gi();y[i]=gi();
modify(1,1,w,x,i);
}
for(int i=1;i<=m;i++){
int p=gi();t[i]=gi();L[i]=gi();R[i]=gi();D[i]=gi();U[i]=gi();
vec[p].push_back(i);
}
for(int v:vec[1])q.push(mp(t[v],v));
dis[1]=0;vis[1]=1;
while(!q.empty()){
int u=q.top().second,d=q.top().first;q.pop();
Del(1,1,n,u,d);
}
for(int i=2;i<=n;i++)printf("%d\n",dis[i]);
return 0;
}
原文地址:https://www.cnblogs.com/fexuile/p/11690311.html
- hdu------(4300)Clairewd’s message(kmp)
- TensorFlow ML cookbook 第一章7、8节 实现激活功能和使用数据源
- Go语言struct类型详解
- spark1.x升级spark2如何升级及需要考虑的问题
- 使用 kubeadm 创建一个 kubernetes 集群
- Oracle 12c 多租户专题|CDB元数据内幕
- 深入分析golang多值返回以及闭包的实现
- Hadoop3.0扩展Yarn资源模型详解2:资源Profiles说明
- hdu------(1525)Euclid's Game(博弈决策树)
- Go语言指针访问结构体的方法
- Spring Boot & Spring Cloud 应用内存管理
- hdu----(1849)Rabbit and Grass(简单的尼姆博弈)
- 10分钟让你明白MySQL是如何利用索引的
- 扩展Yarn资源模型详解1
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- 详解Android Selinux 权限及问题
- Android图片采样缩放功能实例代码
- Android开发中使用Intent打开第三方应用及验证可用性的方法详解
- Android 7.0开发获取存储设备信息的方法
- Android中默认系统的声音/大小修改和配置详解
- Android开发中计算器的sin、cos及tan值计算问题分析
- Android开发实现绘制淘宝收益图折线效果示例
- Android自定义View实现搜索框(SearchView)功能
- android 监听SD卡文件变化的实现代码
- Android监听手机短信的示例代码
- Android开发之图片压缩工具类完整实例
- Android6.0开发中屏幕旋转原理与流程分析
- Android中WebView的基本配置与填坑记录大全
- Android开发实现ListView异步加载数据的方法详解
- Android开发实现AlertDialog中View的控件设置监听功能分析