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 ...
随机推荐
- docker centos:latest 使用 sshd
一.术语 1.容器 很多用户在接触Docker 之初都会认为容器就是一种轻量级的虚拟机,但实际上,容器和虚拟机有非常大的区别.从根本形态上来看,容器其实就是运行在操作系统上的一个进程,只不过加入了对资 ...
- Codeforces 807C - Success Rate(二分枚举)
题目链接:http://codeforces.com/problemset/problem/807/C 题目大意:给你T组数据,每组有x,y,p,q四个数,x/y是你当前提交正确率,让你求出最少需要再 ...
- python 图片上传写入磁盘功能
本文是采取django框架,前端上传图片后端接收后写入磁盘,数据库记录图片在磁盘上的路径(相对),以下是前端上传到后端入库的基本流程 一. html代码 <!DOCTYPE html> & ...
- sql查询与修改数据库逻辑文件名,移动数据库存储路径
USE mydb GO --1.查询当前数据库的逻辑文件名 ) ) AS 'File Name 2'; --或通过以下语句查询: --SELECT name FROM sys.database_fil ...
- Python 安装 pytesser 处理验证码出现的问题
今天这个问题困扰了我好久,开始直接用 pip install pytesseract 安装了 pytesseract 然后出现了如下错误 Traceback (most recent call las ...
- BFC 从了解到放弃
最近工作中我突然产生了一个想法,就如我们人类面临的终极问题一般,我从哪里来?我到哪里去?在撸代码进行CSS布局的时候,我会去想,我为什么这么做?,为什么浮动的元素要用overflow?,为什么要用cl ...
- HA下的Spark集群工作原理解密
实验环境: zookeeper-3.4.6 Spark:1.6.0 简介: 本篇博客将从以下几点组织文章: 一:Spark 构建高可用HA架构 二:动手实战构建高可用HA 三:提交程序测试HA 一:S ...
- Mybatis入门及Dao开发方式
本节内容: Mybatis介绍 使用jdbc编程问题总结 Mybatis架构 Mybatis入门程序 Dao的开发方式 SqlMapConfig.xml文件说明 一.Mybatis介绍 MyBatis ...
- 好久没有写过SQL了,今天写了一句select in留存
应同事要求,直接去接数据库的数据. 数据C里有一个name是查询的起始. 然后,B其实是一个多对多的中间表, 通过B查出id之后, 就可以在A里找到需要的数据了. select name from A ...
- spring-boot分环境打包为war包
1.启动类修改 @EnableSwagger2 @SpringBootApplication public class CustWebAcApplication extends SpringBootS ...