結果
問題 | No.686 Uncertain LIS |
ユーザー | xxyPerta |
提出日時 | 2023-12-31 18:06:23 |
言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
結果 |
WA
|
実行時間 | - |
コード長 | 2,752 bytes |
コンパイル時間 | 1,661 ms |
コンパイル使用メモリ | 169,264 KB |
実行使用メモリ | 14,844 KB |
最終ジャッジ日時 | 2024-09-27 17:08:00 |
合計ジャッジ時間 | 8,233 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge1 |
(要ログイン)
テストケース
テストケース表示入力 | 結果 | 実行時間 実行使用メモリ |
---|---|---|
testcase_00 | AC | 3 ms
12,652 KB |
testcase_01 | AC | 3 ms
6,816 KB |
testcase_02 | AC | 3 ms
6,940 KB |
testcase_03 | AC | 2 ms
6,940 KB |
testcase_04 | AC | 2 ms
6,940 KB |
testcase_05 | AC | 3 ms
6,944 KB |
testcase_06 | AC | 3 ms
6,944 KB |
testcase_07 | AC | 2 ms
6,940 KB |
testcase_08 | AC | 3 ms
6,940 KB |
testcase_09 | AC | 126 ms
6,988 KB |
testcase_10 | AC | 111 ms
6,988 KB |
testcase_11 | AC | 69 ms
6,944 KB |
testcase_12 | AC | 5 ms
6,940 KB |
testcase_13 | AC | 32 ms
6,940 KB |
testcase_14 | WA | - |
testcase_15 | WA | - |
testcase_16 | WA | - |
testcase_17 | WA | - |
testcase_18 | AC | 154 ms
8,824 KB |
testcase_19 | AC | 145 ms
8,880 KB |
testcase_20 | WA | - |
testcase_21 | WA | - |
testcase_22 | WA | - |
testcase_23 | WA | - |
testcase_24 | AC | 67 ms
6,988 KB |
testcase_25 | AC | 68 ms
6,988 KB |
testcase_26 | TLE | - |
testcase_27 | -- | - |
testcase_28 | -- | - |
testcase_29 | -- | - |
testcase_30 | -- | - |
testcase_31 | -- | - |
testcase_32 | -- | - |
testcase_33 | -- | - |
testcase_34 | -- | - |
testcase_35 | -- | - |
ソースコード
#include<bits/stdc++.h> using namespace std; inline int read() { int x=0;char ch=getchar(); while(!isdigit(ch)) ch=getchar(); while(isdigit(ch)) x=(x<<3)+(x<<1)+(ch^48),ch=getchar(); return x; } const int N=6e5+10; int n,ans,cnt,root; int Fa[N],num[N],son[N][2],tag[N]; inline void Max(int &x,int y) {x=x>y?x:y;} bool loc(int x) {return son[Fa[x]][1]==x;} void inc(int x) { if(!tag[x]||!x) return; num[son[x][0]]+=tag[x]; tag[son[x][0]]+=tag[x]; num[son[x][1]]+=tag[x]; tag[son[x][1]]+=tag[x]; tag[x]=0; } void rot(int x) { int fa=Fa[x],ffa=Fa[fa],L=loc(x); inc(x),inc(fa); son[fa][L]=son[x][L^1]; Fa[son[fa][L]]=fa; if(ffa) son[ffa][loc(fa)]=x; Fa[fa]=x; Fa[x]=ffa; son[x][L^1]=fa; } void splay(int x,int up) { for(int fa;(fa=Fa[x])!=up;rot(x)) if(Fa[fa]!=up) rot(loc(x)==loc(fa)?fa:x); if(!up) root=x; } int pree(int x) { int now=root,res=-1; while(now) { inc(now); if(num[now]<x) res=now,now=son[now][1]; else now=son[now][0]; } return res; } int suff(int x) { int now=root,res=-1; while(now) { inc(now); if(num[now]>=x) res=now,now=son[now][0]; else now=son[now][1]; } return res; } void add(int x) { int ned=suff(x); if(!~ned) { ned=pree(x); assert(~ned); splay(ned,0); inc(ned); Fa[++cnt]=ned,num[cnt]=x,son[cnt][1]=son[ned][1]; Fa[son[ned][1]]=cnt; son[ned][1]=cnt; splay(cnt,0); return; } splay(ned,0); inc(ned); Fa[++cnt]=ned,num[cnt]=x,son[cnt][0]=son[ned][0]; Fa[son[ned][0]]=cnt; son[ned][0]=cnt; splay(cnt,0); } void del(int x) { while(1) if(son[x][0]) rot(son[x][0]); else if(son[x][1]) rot(son[x][1]); else break; son[Fa[x]][loc(x)]=0; splay(Fa[x],0); } void dfs(int x) { ++ans; if(son[x][0]) dfs(son[x][0]); if(son[x][1]) dfs(son[x][1]); } int main() { n=read(); cnt=root=1; for(int i=1,l,r;i<=n;i++) { l=read(),r=read(); if(i==1) {num[1]=l;continue;} int suf=suff(r),ned=pree(l); if(~suf&&~ned) { splay(suf,0); splay(ned,suf); num[son[ned][1]]++; tag[son[ned][1]]++; } else if(~suf) { splay(suf,0); num[son[suf][1]]++; tag[son[suf][1]]++; } else if(~ned) { splay(ned,0); num[son[ned][1]]++; tag[son[ned][1]]++; } else { num[root]++; tag[root]++; } add(l); if(~suf) del(suf); num[0]=tag[0]=0; } dfs(root); printf("%d\n",ans); return 0; }