Codeforces Round #222 (Div. 1) D. Developing Game 扫描线
D. Developing Game
题目连接:
http://www.codeforces.com/contest/377/problem/D
Description
Pavel is going to make a game of his dream. However, he knows that he can't make it on his own so he founded a development company and hired n workers of staff. Now he wants to pick n workers from the staff who will be directly responsible for developing a game.
Each worker has a certain skill level vi. Besides, each worker doesn't want to work with the one whose skill is very different. In other words, the i-th worker won't work with those whose skill is less than li, and with those whose skill is more than ri.
Pavel understands that the game of his dream isn't too hard to develop, so the worker with any skill will be equally useful. That's why he wants to pick a team of the maximum possible size. Help him pick such team.
Input
The first line contains a single integer n (1 ≤ n ≤ 105) — the number of workers Pavel hired.
Each of the following n lines contains three space-separated integers li, vi, ri (1 ≤ li ≤ vi ≤ ri ≤ 3·105) — the minimum skill value of the workers that the i-th worker can work with, the i-th worker's skill and the maximum skill value of the workers that the i-th worker can work with.
Output
In the first line print a single integer m — the number of workers Pavel must pick for developing the game.
In the next line print m space-separated integers — the numbers of the workers in any order.
If there are multiple optimal solutions, print any of them.
Sample Input
4
2 8 9
1 4 7
3 6 8
5 8 10
Sample Output
3
1 3 4
Hint
题意
有n个人,这个人的属性v,他可以接受能力值在[l,r]里面的人
你是一个老板,你需要雇佣尽量多的人,问你怎么去雇佣……
题解:
感觉是一个网络流的样子,其实不然
假设答案是[L,R]区间,把这个抽象成二维平面上的点
那么对于每一个人,我们可以看做是[l,v],[v,R]这么一个矩形,只要这个矩形包括了那个点
那么这个人就是可选的。
知道这个之后,这道题就是傻逼题了
就直接扫描线莽一波就好了
代码
#include <bits/stdc++.h>
using namespace std;
const int maxn = 3e5 + 15;
struct Point{
int l , r , idx;
Point ( int l , int r , int idx ) : l( l) , r(r) , idx(idx){}
};
vector < Point > add[maxn] , del[maxn];
pair < int , int > Base[maxn];
int N , V[maxn];
struct Sgtree{
struct node{
int l , r , maxv , lazy , maxr;
void Update( int x ){
lazy += x;
maxv += x;
}
}tree[maxn << 2];
void ReleaseLabel( int o ){
tree[o << 1].Update( tree[o].lazy);
tree[o << 1|1].Update(tree[o].lazy);
tree[o].lazy = 0;
}
void Maintain( int o ){
if( tree[o << 1].maxv > tree[o << 1 |1].maxv ) tree[o].maxr = tree[o << 1].maxr;
else tree[o].maxr = tree[o << 1 | 1].maxr;
tree[o].maxv = max( tree[o << 1].maxv , tree[o << 1 | 1].maxv );
}
void Modify( int ql , int qr , int v , int o){
int l = tree[o].l , r = tree[o].r;
if( ql <= l && r <= qr ) tree[o].Update( v );
else{
int mid = l + r >> 1;
ReleaseLabel( o );
if( ql <= mid ) Modify( ql , qr , v , o << 1 );
if( qr > mid ) Modify( ql , qr , v , o << 1 | 1 );
Maintain( o );
}
}
void Build( int l , int r , int o ){
tree[o].l = l , tree[o].r = r , tree[o].maxv = 0 , tree[o].maxr = r;
if( r > l ){
int mid = l + r >> 1;
Build( l , mid , o << 1 );
Build( mid + 1 , r , o << 1 | 1);
}
}
int ask( int ql , int qr , int o ){
int l = tree[o].l , r = tree[o].r;
if( ql <= l && r <= qr ) return tree[o].maxv;
else{
int mid = l + r >> 1 , rs = -1;
ReleaseLabel( o );
if( ql <= mid ) rs = max( rs , ask( ql , qr , o << 1) );
if( qr > mid ) rs = max( rs , ask( ql , qr , o << 1 | 1) );
Maintain( o );
return rs;
}
}
}Sgtree;
int main( int argc , char * argv[]){
Sgtree.Build(1 , 300000 , 1);
scanf("%d",&N);
for(int i = 1 ; i <= N ; ++ i){
int l , r , v;
scanf("%d%d%d",&l,&v,&r);
add[l].push_back(Point(v,r,i));
del[v].push_back(Point(v,r,i));
Base[i] = make_pair( l , r );
V[i] = v;
}
int mx = 0 , ansl = -1 , ansr = -1;
for(int i = 1 ; i <= 3e5 ; ++ i){
for(int j = 0 ; j < add[i].size() ; ++ j){
int l = add[i][j].l;
int r = add[i][j].r;
Sgtree.Modify( l , r , 1 , 1 );
}
int newmx = Sgtree.tree[1].maxv;
if( newmx > mx ){
mx = newmx , ansl = i , ansr = Sgtree.tree[1].maxr;
assert( Sgtree.ask( ansr , ansr , 1 ) == newmx );
}
for(int j = 0 ; j < del[i].size() ; ++ j){
int l = del[i][j].l;
int r = del[i][j].r;
Sgtree.Modify( l , r , -1 , 1 );
}
}
printf("%d\n" , mx );
vector < int > out;
for(int i = 1 ; i <= N ; ++ i)
if( Base[i].first <= ansl && Base[i].second >= ansr && V[i] <= ansr && V[i] >= ansl )
out.push_back( i );
for(int i = 0 ; i < out.size() ; ++ i) printf("%d " ,out[i]);
printf("\n");
return 0;
}
Codeforces Round #222 (Div. 1) D. Developing Game 扫描线的更多相关文章
- Codeforces Round #222 (Div. 1) D. Developing Game 线段树有效区间合并
D. Developing Game Pavel is going to make a game of his dream. However, he knows that he can't mak ...
- Codeforces Round #222 (Div. 1) D. Developing Game
D - Developing Game 思路:我们先枚举左边界,把合法的都扣出来,那么对于这些合法的来说值有v 和 r两维了,把v, r看成线段的两端, 问题就变成了,最多能选多少线段 使得不存在这样 ...
- Codeforces Round #322 (Div. 2) C. Developing Skills 优先队列
C. Developing Skills Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/contest/581/p ...
- Codeforces Round #222 (Div. 1) C. Captains Mode 对弈+dp
题目链接: http://codeforces.com/contest/378/problem/E 题意: dota选英雄,现在有n个英雄,m个回合,两支队伍: 每一回合两个选择: b 1,队伍一ba ...
- Codeforces Round #222 (Div. 1) C. Captains Mode 状压
C. Captains Mode 题目连接: http://codeforces.com/contest/377/problem/C Description Kostya is a progamer ...
- Codeforces Round #222 (Div. 1) B. Preparing for the Contest 二分+线段树
B. Preparing for the Contest 题目连接: http://codeforces.com/contest/377/problem/B Description Soon ther ...
- Codeforces Round #222 (Div. 1) A. Maze dfs
A. Maze 题目连接: http://codeforces.com/contest/377/problem/A Description Pavel loves grid mazes. A grid ...
- Codeforces Round #222 (Div. 1) Maze —— dfs(连通块)
题目链接:http://codeforces.com/problemset/problem/377/A 题解: 有tot个空格(输入时统计),把其中k个空格变为wall,问怎么变才能使得剩下的空格依然 ...
- Codeforces Round #222 (Div. 1) (ABCDE)
377A Maze 大意: 给定棋盘, 保证初始所有白格连通, 求将$k$个白格变为黑格, 使得白格仍然连通. $dfs$回溯时删除即可. #include <iostream> #inc ...
随机推荐
- mysql高可用架构 -> MHA部署-04
MHA架构图 本次MHA的部署基于GTID复制成功构建,普通主从复制也可以构建MHA架构. 下载所需的软件包 mkdir /server/tools -p //创建存放包的目录 [root@db01 ...
- 12 Release History for go go语言的版本历史
Release History Release Policy go1.11 (released 2018/08/24) go1.10 (released 2018/02/16) Minor revis ...
- 利用mysql的binlog恢复数据
MySQL Binary Log也就是常说的bin-log, ,是mysql执行改动产生的二进制日志文件,其主要作用有两个: * 数据回复 * 主从数据库.用于slave端执行增删改,保持与maste ...
- 如何在VS2013创建WebService并在IIS中发布
第一步:打开VS2013,选择文件->新建->项目. 第二步:选择[ASP.net 空web应用程序],将其命名为自己想的工程名称. 第三步:然后右键点击工程,添加->web服务.然 ...
- Linux学习笔记:ls和ll命令
list显示当前目录中的文件名字,不加参数时显示除隐藏文件外的所有文件及目录的名字. ll 等同于 ls -l-r 对目录反向排序(按字母)-t 以时间排序-u 以文件上次被访问的时间排序-x 按列输 ...
- CCF CSP 201403-2 窗口
CCF计算机职业资格认证考试题解系列文章为meelo原创,请务必以链接形式注明本文地址 CCF CSP 201403-2 窗口 问题描述 在某图形操作系统中,有 N 个窗口,每个窗口都是一个两边与坐标 ...
- vuejs、eggjs、mqtt全栈式开发设备管理系统
vuejs.eggjs.mqtt全栈式开发简单设备管理系统 业余时间用eggjs.vuejs开发了一个设备管理系统,通过mqtt协议上传设备数据至web端实时展现,包含设备参数分析.发送设备报警等模块 ...
- 【LOJ】#2068. 「SDOI2016」探险路线
题解 少考虑了情况,导致我以为是暴力讨论一次角落移动 de了两天才反应过来--简直降智 事实上,我们把移动分三类,一种是在边界跳过一段,一种是在左上角上左上左上左这样撞墙,在右下角下右下右下右这么撞墙 ...
- 在VMware虚拟机中安装Mac OS 操作系统
1. 安装VMware 我这里是安装VMWARE12.exe,其他的版本我不知道是否可以正常运行,最好大家安装12版本的比较好. 2. 安装 Mac OS X Unlocker for VMware ...
- Python爬虫个人记录(三)爬取妹子图
这此教程可能会比较简洁,具体细节可参考我的第一篇教程: Python爬虫个人记录(一)豆瓣250 Python爬虫个人记录(二)fishc爬虫 一.目的分析 获取煎蛋妹子图并下载 http://jan ...