#include <iostream>
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <cmath>
#define R(a,b,c) for(register int a = (b); a <= (c); ++ a)
#define nR(a,b,c) for(register int a = (b); a >= (c); -- a)
#define Max(a,b) ((a) > (b) ? (a) : (b))
#define Min(a,b) ((a) < (b) ? (a) : (b))
#define Fill(a,b) memset(a, b, sizeof(a))
#define Swap(a,b) a^=b^=a^=b
#define ll long long
#define ON_DEBUG #ifdef ON_DEBUG #define D_e_Line printf("\n\n----------\n\n")
#define D_e(x) cout << #x << " = " << x << endl #else #define D_e_Line ; #endif struct ios{
template<typename ATP>ios& operator >> (ATP &x){
x = 0; int f = 1; char c;
for(c = getchar(); c < '0' || c > '9'; c = getchar()) if(c == '-') f = -1;
while(c >= '0' && c <= '9') x = x * 10 + (c ^ '0'), c = getchar();
x*= f;
return *this;
}
}io;
using namespace std; const int N = 50007; struct node{
int l,r,fa,id;
int val,pri;
bool operator < (const node &com)const{
return val < com.val;
}
}t[N],ans[N]; inline void Insert(int rt){
int tmp;
for(tmp = rt - 1; t[tmp].pri > t[rt].pri; tmp = t[tmp].fa);
t[rt].l = t[tmp].r;
t[t[tmp].r].fa = rt;
t[rt].fa = tmp;
t[tmp].r = rt;
} int vis[30007];
int main(){
int n;
while(scanf("%d", &n) != EOF){
Fill(vis, false);
int flag = true;
R(i,0,n){
t[i].l = t[i].r = t[i].fa = 0;
t[i].w = -0x7fffffff;
} R(i,1,n){
scanf("%d%d", &t[i].val, &t[i].w);
t[i].id = i;
if(vis[t[i].val])
flag = false;
else
vis[t[i].val] = true;
}
if(!flag){
printf("NO\n");
continue;
}
printf("YES\n"); sort(t + 1, t + n + 1); R(i,1,n) Insert(i); R(i,1,n){
if(!t[i].l)
ans[t[i].id].l = 0;
else
ans[t[i].id].l = t[t[i].l].id;
if(!t[i].r)
ans[t[i].id].r = 0;
else
ans[t[i].id].r = t[t[i].r].id;
if(!t[i].fa)
ans[t[i].id].fa = 0;
else
ans[t[i].id].fa = t[t[i].fa].id;
} R(i,1,n)
printf("%d %d %d\n", ans[i].fa, ans[i].l, ans[i].r);
} return 0;
}

最新文章

  1. Sicily 1051: 魔板(BFS+排重)
  2. MongoDB-基础-条件操作符
  3. js-DOM2,表单脚本
  4. zz---Tomcat服务器下部署项目几种方式
  5. 包装类型的比较,如:Integer,Long,Double
  6. 28个你必须知道的HTML5的新特性,技巧以及技术
  7. DbUtility-第一次接触
  8. jQuery效果-滑动
  9. Android Sensor Test
  10. php phalcon
  11. Django解决 &#39;ascii&#39; codec can&#39;t encode characters in position
  12. javascript中关于this的理解
  13. hdoj1242(bfs+priority_queue)
  14. spring事务详解
  15. AppCompatActivity 去掉标题栏和EditText弹出软键盘遮住输入框问题
  16. Kotlin入门教程——目录索引
  17. MongoDB Redis
  18. 更改Oracle字符集避免乱码
  19. [Linux]Linux下修改snmp协议的默认161端口
  20. curd——5

热门文章

  1. 值得注意的: c++动态库、静态库、弱符号__attribute__((weak))以及extern之间的关系
  2. 07makefile文件
  3. SQL如何用表A更新表B
  4. Eoapi — 一个可拓展的开源 API 工具
  5. Halodoc使用 Apache Hudi 构建 Lakehouse的关键经验
  6. ElasticSearch6.4.2
  7. 聊聊消息中间件(1),AMQP那些事儿
  8. KALI2020忘记用户名和密码
  9. 高级web网页人脸识别tracking.js
  10. 基于Vue.js的Web视频播放器插件vue-vam-video@1.3.6 正式发布