某考试 T2 Seg
Seg
【问题描述】
数轴上有n条线段,第i条线段的左端点是a[i],右端点是b[i]。
Bob发现1~2n共2n个整数点,每个点都是某条线段的端点。
这些线段有如下两类特点:
1 x y,表示第x条线段和第y条线段相交(相交在这里指至少有一个公共点)
2 x y,表示第x条线段在第y条线段的左边,且它们不相交。
共有m个特点,每个特点都是如上两类之一。
Bob想通过这些特点推理得到每条线段的端点。
【输入格式】
第一行两个正整数n,m
接下来m行,每行三个正整数,描述线段的特点,格式见题目描述
【输出格式】
输出n行,第i行两个正整数,用空格隔开,分别是a[i]和b[i]
可能有多种答案,输出字典序最小的答案。即先要求a[1]最小,若仍有多解再要求b[1]最小,若仍有多解再要求a[2]最小,若仍有多解再要求b[2]最小,若仍有多解再要求a[3]最小……
如果无解输出“Wrong”(不输出引号)。
【样例输入】
3 2
1 2 3
2 1 3
【样例输出】
1 2
3 5
4 6
【数据规模和约定】
对于30%的数据, 1<=n,m<=10
对于60%的数据, 1<=n,m<=1000
对于100%的数据,1<=n,m<=100000
题解在注释里有,要注意的就是一点,我们如果要求一个字典序最小的拓扑排序,正确的做法并不是尽量把小的塞到前面,
而是把大的尽量塞到后面。
这个要理解的话,就是如果我们尽量把小的噻前面,有可能一个优先级很高的是一个优先级很低的后继,这时候因为优先队列是优先出小的
所以那个优先级很高的会很晚出来。
而我们如果反着跑的话,是不会出现这种情况的,因为优先级低的会被挤到后面去。
/*
可以把每条线段的左右端点都看成一个变量。
设第i条线段的左右端点的变量为l[i],r[i]。 条件1 => l[x]<r[y] && l[y]<r[x]
条件2 => r[x]<l[y] 所以我们把大小关系拓扑建图一下,然后跑一个
优先编号小的线段端点,优先同一线段的左端点的
拓扑排序,这个用一下优先队列就行了。
*/
#include<bits/stdc++.h>
#define ll long long
#define pb push_back
#define maxn 200005
using namespace std;
int ans[maxn],cnt=0,now,las;
int n,id[maxn],m,opt,X,Y;
priority_queue<int> q;
vector<int> g[maxn]; inline void topsort(){
for(int i=1;i<=now;i++) if(!id[i]) q.push(i);
int x,to;
while(!q.empty()){
x=q.top(),q.pop();
ans[x]=now--;
for(int i=g[x].size()-1;i>=0;i--){
to=g[x][i];
if(!(--id[to])) q.push(to);
}
}
} int main(){
freopen("seg.in","r",stdin);
freopen("seg.out","w",stdout);
scanf("%d%d",&n,&m);
now=n<<1; for(int i=1;i<=n;i++){
g[i*2].pb(i*2-1);
id[i*2-1]++;
} for(int i=1;i<=m;i++){
scanf("%d%d%d",&opt,&X,&Y);
if(opt==1){
g[Y*2].pb(X*2-1),id[X*2-1]++;
g[X*2].pb(Y*2-1),id[Y*2-1]++;
}
else{
g[Y*2-1].pb(X*2);
id[X*2]++;
}
} topsort(); if(now) puts("Wrong");
else for(int i=1;i<=n;i++){
printf("%d %d\n",ans[i*2-1],ans[i*2]);
} return 0;
}
某考试 T2 Seg的更多相关文章
- 9.13 考试 T2 区间
		
删区间 题意: 给出一个长度为
 - 某考试T2   frog
		
题目背景 无 题目描述 数轴上有 n 只青蛙,分别编号为 1 到 n.青蛙 i 的初始位置的坐标为 xi. 它们准备进行如下形式的移动:每轮包括 m 次跳跃,第 i 次跳跃由青蛙 ai(1 < ...
 - 某考试 T2 Tree
		
2 树 2.1 题目描述 给一棵n 个节点的树,节点分别编号为0 到n - 1.你可以通过如下的操作来修改这棵树:首先先删去树上的一条边,此时树会分裂为两个连通块,然后在两个连通块之间加上一条新的边使 ...
 - 某考试 T2 yja
		
2.1 Description 在平面上找 n 个点, 要求这 n 个点离原点的距离分别为 r1, r2, ..., rn. 最大化这 n 个点构成的凸包面积, 凸包上的点的顺序任意. 2.2 Inp ...
 - 题解 2020.10.24 考试 T2 选数
		
题目传送门 题目大意 见题面. 思路 本来以为zcx.pxj变强了,后来发现是SPJ出问题了...考试的时候感觉有点人均啊...结果自己还是只想出来一半. 我们假设 \(f(x)=(\lfloor\f ...
 - 2019.3.7考试T2  离线数论??
		
$ \color{#0066ff}{ 题目描述 }$ 一天,olinr 在 luogu.org 刷题,一点提交,等了一分钟之后,又蛙又替. olinr 发动了他的绝招,说:"为啥啊???&q ...
 - 某考试 T2 orzcyr
		
非常nice的一道行列式的题目. 考虑如果没有路径不相交这个限制的话,那么这个题就是一个行列式:设 a[i][j] 为从编号第i小的源点到编号第j小的汇点的路径条数,那么矩阵a[][]的行列式就是的答 ...
 - 2019.2.26考试T2  矩阵快速幂加速DP
		
\(\color{#0066ff}{题解 }\) 可以发现, 数据范围中的n特别小,容易想到状压 可以想到类似于状压DP的思路,按列进行转移 那么应该有3维,\(f[i][j][k]\)代表到第i列, ...
 - 2019.2.10考试T2, 多项式求exp+生成函数
		
\(\color{#0066ff}{ 题目描述 }\) 为了减小文件大小,这里不写一堆题目背景了. 请写一个程序,输入一个数字N,输出N个点的森林的数量.点有标号. 森林是一种无向图,要求图中不能存在 ...
 
随机推荐
- Python及其常用模块库下载及安装
			
一.Python下载:https://www.python.org/downloads/ 二.Python模块下载:http://www.lfd.uci.edu/~gohlke/pythonlibs/ ...
 - 9 RESTful API
			
1 RESTful API 2 post创建一个视频 put帖子加精,delete删除 3 自定义状态码 4 5 6 7 8
 - Proguard returned with error code 1. See console
			
满世界的bug. 微信支付,Windows的远程桌面. Android的 , Proguard returned with error code 1. See console解决办法" 真的 ...
 - loj2035 「SDOI2016」征途
			
学了斜率优化这题就能一气呵成地做出来啦qwqqwq #include <iostream> #include <cstdio> using namespace std; typ ...
 - 使用WMI Filter 实现组策略的筛选!
			
今天接到一个客户的一个问题,提到需要分系统版本分发相应的MSI程序.比如简体版接受简体版的分发程序,繁体版接受繁体版的分发程序!这个建立组策略的不同版本分发本身不会太难,我们只需要建立两个不同组策略分 ...
 - 【Luogu P1120】小木棍
			
题目: 乔治有一些同样长的小木棍,他把这些木棍随意砍成几段,直到每段的长都不超过$50$.现在,他想把小木棍拼接成原来的样子,但是却忘记了自己开始时有多少根木棍和它们的长度.给出每段小木棍的长度,编程 ...
 - apizza导出为html后,从中提取api_name/api_path/api_method,保存到本地,方便根据接口名称得到接口路径与请求方法
			
import re import os def open_file(file='c:/newcrm.html'): f=open(file,'r',encoding='utf-8') return f ...
 - Python+Selenium练习篇之11-浏览器上前进和后退操作
			
本文来介绍上如何,利用webdriver中的方法来演示浏览器中地址栏旁边的前进和后退功能. 相关脚本代码如下: # coding=utf-8import timefrom selenium impor ...
 - java线程安全问题原因及解决办法
			
1.为什么会出现线程安全问题 计算机系统资源分配的单位为进程,同一个进程中允许多个线程并发执行,并且多个线程会共享进程范围内的资源:例如内存地址.当多个线程并发访问同一个内存地址并且内存地址保存的值是 ...
 - 数据库——初始mysql语句(2)
			
sql语句 #1. 操作文件夹(库) 增:create database db1 charset utf8; 查:show create database db1; show databases; 改 ...