codeforces #310 div1 B
我们考虑n-1座桥每座桥需要的长度在一个区间[L,R]中
之后我们现在有m座桥,每个桥的长度为k
题意就是要求一个匹配方案
显然如果数据范围不大直接KM就可以了
可是20w的数据KM显然要T
所以我们考虑这是个区间问题,我们可以贪心
考虑两座桥A,B, A的区间被B的区间所包含
那么优先考虑A总比优先考虑B优
所以我们可以将区间按右端点从小到大排序,这样被包含的区间永远是优先考虑的
之后我们考虑选哪个点与当前区间匹配
这个时候可以考虑当前的决策对后面的影响
如果后面的区间包含当前区间,那么无论怎样决策都会使后面区间可选点-1
如果后面的区间不包含当前区间,那么选尽可能靠左的可行点对后面区间的影响最小
所以我们对于每个区间选可行的最靠左的点与之匹配,用set维护即可
#include<cstdio>
#include<cstdlib>
#include<algorithm>
#include<cstring>
#include<iostream>
#include<set>
using namespace std; typedef long long LL;
const int maxn=200010;
int n,m;
LL A[maxn],B[maxn];
struct Segment{
LL L,R;
int id;
}t[maxn];
struct bridge{
LL len;
int id;
}c[maxn];
int ans[maxn];
set<pair<LL,int> >S;
bool cmp(const Segment &A,const Segment &B){
if(A.R==B.R)return A.L>B.L;
return A.R<B.R;
} int main(){
scanf("%d%d",&n,&m);
if(m<n-1){printf("No\n");return 0;}
for(int i=1;i<=n;++i){
scanf("%I64d%I64d",&A[i],&B[i]);
if(i>1){t[i-1].L=A[i]-B[i-1],t[i-1].R=B[i]-A[i-1],t[i-1].id=i-1;}
}
for(int i=1;i<=m;++i){
scanf("%I64d",&c[i].len);
c[i].id=i;
S.insert(make_pair(c[i].len,c[i].id));
}
sort(t+1,t+n,cmp);
for(int i=1;i<n;++i){
pair<LL,int>p=*S.lower_bound(make_pair(t[i].L,-1));
if(p.first<t[i].L){printf("No\n");return 0;}
if(p.first>t[i].R){printf("No\n");return 0;}
else ans[t[i].id]=p.second;
S.erase(p);
}
printf("Yes\n");
for(int i=1;i<n;++i)printf("%d ",ans[i]);
return 0; }
codeforces #310 div1 B的更多相关文章
- codeforces #310 div1 E
算得上是比较水的E题了吧,自己想了想写了写居然1A了 对于这道题,我们很容易想到对于原图的一个边双,定向后任意两点间一定可达 那么我们可以求出原图的边双并将每个边双缩成一个点 那么原图就变成了无环的无 ...
- codeforces #310 div1 D
一开始写了个暴力模拟绳子的摆动轨迹 然后在Test 16 T掉了 后来%了一下别人的代码,发现需要对特殊情况进行特殊处理 首先我们考虑绳子的向右摆动,设当前位置为p,绳子当前长度为L 如果其旋转中心位 ...
- codeforces #310 div1 C
操作无论是U还是L,都会使原图形分裂成两个图形,且两个图形的操作互不影响 我们又发现由于操作点只可能在下斜线上,如果将操作按x排序 那么无论是U还是L,都会将操作序列完整分割成两半,且两个操作序列互不 ...
- codeforces #310 div1 A
首先我们考虑最暴力的拆解拼凑 显然拆分掉所有的链需要 n-m 次 之后拼凑需要 n-1 次 然后由题目规定可知:只有从1出发且连续的链不用拆掉,其余的都必须拆掉(因为两个都套有娃娃的套娃不能组合) 我 ...
- codeforces 407 div1 B题(Weird journey)
codeforces 407 div1 B题(Weird journey) 传送门 题意: 给出一张图,n个点m条路径,一条好的路径定义为只有2条路径经过1次,m-2条路径经过2次,图中存在自环.问满 ...
- codeforces 407 div1 A题(Functions again)
codeforces 407 div1 A题(Functions again) Something happened in Uzhlyandia again... There are riots on ...
- codeforces #313 div1 E
首先我们要注意到一个事情 如果一个灯塔向左覆盖,那么比他小的某个灯塔如果向左覆盖的端点大于当前塔向左覆盖的端点,他一定向右覆盖 对于当前灯塔向右覆盖也是同理 那么我们只需要记录当前覆盖到的端点就可以完 ...
- codeforces #305 div1 done
总算搞定了这一场比赛的题目,感觉收获蛮大 其中A,B,C都能通过自己的思考解决掉 D题思路好神,E题仔细想想也能想出来 以后坚持每两天或者一天做一场CF的div1的全套题目 除非有实在无法做出来的题目 ...
- Codeforces #254 div1 B. DZY Loves FFT 暴力乱搞
B. DZY Loves FFT 题目连接: http://codeforces.com/contest/444/problem/B Description DZY loves Fast Fourie ...
随机推荐
- easyui combobox 模糊检索数据并填充
$("#id"),combobox({ url:'', ...... filter:function(q,row){ var op = $(this).combobox(&qu ...
- 转:ASP.NET中的SESSION实现与操作方法
在ASP.NET中,状态的保持方法大致有:ApplicationState,SessionState,Cookie,配置文件,缓存. ApplicationState 的典型应用如存储全局数据. Se ...
- JavaScript、jQuery、HTML5、Node.js实例大全-读书笔记1
技术很多,例子很多,只好慢慢学,慢慢实践!!现在学的这本书是[JavaScript实战----JavaScript.jQuery.HTML5.Node.js实例大全] 第 3 章 用 JavaScri ...
- Js跳出循环
break和 continue break 中断整个循环 continue 跳出当前循环,进入下一次循环 break示例: 例1: 例2: Continue:跳出当前循环,进入下一次循环 Break与 ...
- Java+FlexPaper+swfTools 文档在线预览demo
1.概述 主要原理 1.通过第三方工具openoffice,将word.excel.ppt.txt等文件转换为pdf文件 2.通过swfTools将pdf文件转换成swf格式的文件 3.通过FlexP ...
- VS2005上一个坑:关于pch 的 error C1023
昨天编译就报错: c1xx : fatal error C1023: ‘UnicodeDebug\ImEngine.pch’ : unexpected error with pch, try rebu ...
- 《java编程思想》--多线程基础--Runnable
一.简单说下Runnable是什么 1.它是一个接口 2.只提供了run方法 3.这个接口提供了一个协议:实现这个接口的类是active的(不必成为Thread的子类) 4.run方法没有返回值 /* ...
- 内存管理算法--Buddy伙伴算法
Buddy算法的优缺点: 1)尽管伙伴内存算法在内存碎片问题上已经做的相当出色,但是该算法中,一个很小的块往往会阻碍一个大块的合并,一个系统中,对内存块的分配,大小是随机的,一片内存中仅一个小的内存块 ...
- Responsive设计——不同设备的分辨率写法
1.1024px显屏 @media screen and (max-width : 1024px) { /* 样式写在这里 */ } 2.800px显屏 @media screen and (max- ...
- jQuery ui 中文日历
jQuery ui 中文日历 <link href="css/jquery-ui-1.10.4.custom.min.css" rel="stylesheet&qu ...