某考试 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个点的森林的数量.点有标号. 森林是一种无向图,要求图中不能存在 ...
随机推荐
- php代码审计 strcmp和MD5函数漏洞
通过get得到三个值,v1,v2,v3. if第一层判断,v1和v2得到的值不一样,但是对它们进行md5加密后的值得相等. if第二层判断,v3得到的值得和$flag的值相等,满足这两个条件输出fla ...
- Python 拓展之推导式
写在之前 推导式是从一个或多个迭代器快速简洁的创建数据结构的一种办法,它可以将循环和条件判断结合,从而可以避免语法冗长的代码. 列表推导式 我在之前的文章中(零基础学习 Python 之 for 循环 ...
- 计算几何-凸包-toleft test
toLeftTest toLeftTest是判断一个点是否在有向直线左侧的算法. 当点s位于向量pq左侧时,toLeftTest返回true.当点s位于向量pq右侧时,toLeftTest返回fals ...
- [DM8168]Linux下控制GPIO实现LED流水灯
首先加载驱动模块,应用程序通过调用API实现GPIO控制功能. 驱动程序: /* * fileName: led_gpio.c * just for LED GPIO test * GP1_14 -& ...
- C++ bitset类的使用与简介
有些程序要处理二进制位的有序集,每个位可能包含的是0(关)或1(开)的值.位是用来保存一组项或条件的yes/no信息(有时也称标志)的简洁方法.标准库提供了bitset类使得处理位集合更容易一些.要使 ...
- Block Nested-Loop 和 Batched Key Access
官方文档:https://dev.mysql.com/doc/refman/5.7/en/bnl-bka-optimization.html BNL和BKA是MySQL 表关联的两种关联算法 比如t1 ...
- Unity开发VR——Oculus Rif_将Oculus接入Unity
该文档基于 Unity2018.3.12f1 1. 搭建简单场景 2. 设置,选择 Edit - Project Setting(若已经勾选,就去掉在勾选一次) 完成该步骤之后,可以带上Oculus头 ...
- Log4j官方文档翻译(二、架构设计)
log4j遵循层次化架构,每个层都有不同的对象来执行不同的任务.这种层次话的结构灵活设计.易于未来的扩展. log4j框架中有两种对象: 核心对象:框架的支撑对象,是框架必不可少的组成部分. 支撑对象 ...
- [HNOI2014][bzoj3572] 世界树 [虚树+dp]
题面: 传送门 思路: 一道虚树的好题,是很多虚树博客的入门题目 但是我认为这道题目出的难点和亮点不在于虚树,而在于建出虚树以后dp的思路与实现 下文中为方便描述,用势力范围来表示一个“议事处”管辖的 ...
- HDU 5322 Hope ——NTT 分治 递推
发现可以推出递推式.(并不会) 然后化简一下,稍有常识的人都能看出这是一个NTT+分治的情况. 然而还有更巧妙的方法,直接化简一下递推就可以了. 太过巧妙,此处不表,建议大家找到那篇博客. 自行抄写 ...