POJ2201 Cartesian Tree (cartesian tree)
2024-10-20 13:40:44
#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;
}
最新文章
- Sicily 1051: 魔板(BFS+排重)
- MongoDB-基础-条件操作符
- js-DOM2,表单脚本
- zz---Tomcat服务器下部署项目几种方式
- 包装类型的比较,如:Integer,Long,Double
- 28个你必须知道的HTML5的新特性,技巧以及技术
- DbUtility-第一次接触
- jQuery效果-滑动
- Android Sensor Test
- php phalcon
- Django解决 &#39;ascii&#39; codec can&#39;t encode characters in position
- javascript中关于this的理解
- hdoj1242(bfs+priority_queue)
- spring事务详解
- AppCompatActivity 去掉标题栏和EditText弹出软键盘遮住输入框问题
- Kotlin入门教程——目录索引
- MongoDB Redis
- 更改Oracle字符集避免乱码
- [Linux]Linux下修改snmp协议的默认161端口
- curd——5
热门文章
- 值得注意的: c++动态库、静态库、弱符号__attribute__((weak))以及extern之间的关系
- 07makefile文件
- SQL如何用表A更新表B
- Eoapi — 一个可拓展的开源 API 工具
- Halodoc使用 Apache Hudi 构建 Lakehouse的关键经验
- ElasticSearch6.4.2
- 聊聊消息中间件(1),AMQP那些事儿
- KALI2020忘记用户名和密码
- 高级web网页人脸识别tracking.js
- 基于Vue.js的Web视频播放器插件vue-vam-video@1.3.6 正式发布