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 扫描线的更多相关文章

  1. 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 ...

  2. Codeforces Round #222 (Div. 1) D. Developing Game

    D - Developing Game 思路:我们先枚举左边界,把合法的都扣出来,那么对于这些合法的来说值有v 和 r两维了,把v, r看成线段的两端, 问题就变成了,最多能选多少线段 使得不存在这样 ...

  3. 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 ...

  4. Codeforces Round #222 (Div. 1) C. Captains Mode 对弈+dp

    题目链接: http://codeforces.com/contest/378/problem/E 题意: dota选英雄,现在有n个英雄,m个回合,两支队伍: 每一回合两个选择: b 1,队伍一ba ...

  5. Codeforces Round #222 (Div. 1) C. Captains Mode 状压

    C. Captains Mode 题目连接: http://codeforces.com/contest/377/problem/C Description Kostya is a progamer ...

  6. 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 ...

  7. Codeforces Round #222 (Div. 1) A. Maze dfs

    A. Maze 题目连接: http://codeforces.com/contest/377/problem/A Description Pavel loves grid mazes. A grid ...

  8. Codeforces Round #222 (Div. 1) Maze —— dfs(连通块)

    题目链接:http://codeforces.com/problemset/problem/377/A 题解: 有tot个空格(输入时统计),把其中k个空格变为wall,问怎么变才能使得剩下的空格依然 ...

  9. Codeforces Round #222 (Div. 1) (ABCDE)

    377A Maze 大意: 给定棋盘, 保证初始所有白格连通, 求将$k$个白格变为黑格, 使得白格仍然连通. $dfs$回溯时删除即可. #include <iostream> #inc ...

随机推荐

  1. Nginx/LVS/HAProxy负载均衡软件的优缺点详解【转】

    转自 (总结)Nginx/LVS/HAProxy负载均衡软件的优缺点详解http://www.ha97.com/5646.html PS:Nginx/LVS/HAProxy是目前使用最广泛的三种负载均 ...

  2. 32 Profiling Go Programs 分析go语言项目

    Profiling Go Programs  分析go语言项目 24 June 2011 At Scala Days 2011, Robert Hundt presented a paper titl ...

  3. Linux下实现多播(组播)

    单播只能发送给一个接收方,但是当给多个接收者发送时,不仅仅耗费流量,而且耗费时间,总流量=每个接收者的流量*接受者. 广播方式是发送给所有的主机,广播的坏处是会造成信息污染,大量的信息会占用网络带宽. ...

  4. mysql中utf8编码的utf8_bin,utf8_general_cs,utf8_bin的区别

    utf8_general_ci 不区分大小写,这个你在注册用户名和邮箱的时候就要使用. utf8_general_cs 区分大小写,如果用户名和邮箱用这个 就会照成不良后果 utf8_bin: com ...

  5. 云计算IaaS浅谈

    (本篇文章仅仅是整理文档资料时,发现的一篇课程报告,感觉还挺有参考意义的) 最近几年云计算一直是IT业的热点,一股炽热的云计算浪潮席卷了世界,全世界都在讲云计算,都在搞云计算.虽然最初是由谷歌公司提出 ...

  6. Oracle学习笔记:ORA-22992 cannot use LOB locators selected from remote tables

    通过DB_LINK访问远程表的时候出现 ORA-22992: cannot use LOB locators selected from remote tables 错误. 原因:因为表中含有clob ...

  7. 计算a+b

    输入: 1 2 结果: 3 说明:只能输入数字,两数间只有一个空格 代码如下:(vc6编译) #include <stdio.h> #include <conio.h> voi ...

  8. C/C++经典面试题

    1.指向数组的指针 和 指向数组首元素的指针 2018-03-07 昨天在牛客上看到这么一道C语言面试题,挺经典的,特来分享给大家. 程序如下,问输出结果 #include <stdio.h&g ...

  9. Android 客户端 okhttp3 与服务器之间的双向验证

    [原文]https://blog.csdn.net/leng_wen_rou/article/details/58596142 本篇是Android 客户端基于okhttp3的网络框架 和后台服务器之 ...

  10. Linux学习笔记——基于鸟哥的Linux私房菜

    Linux学习笔记--基于鸟哥的Linux私房菜 ***** ARM与嵌入式linux的入门建议 (1) 学习基本的裸机编程:ARM7或ARM9,理解硬件架构和控制原理 (这一步是绝对的根基) (2) ...