QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#865200 | #894. Longest Loose Segment | msk_sama | WA | 762ms | 40940kb | C++20 | 2.1kb | 2025-01-21 16:00:52 | 2025-01-21 16:00:52 |
Judging History
answer
#include <set>
#include <map>
#include <queue>
#include <ctime>
#include <cstdio>
#include <vector>
#include <cassert>
#include <cstring>
#include <algorithm>
#define fi first
#define se second
#define ep emplace
#define MISAKA main
#define ll long long
#define eb emplace_back
#define pii pair<int,int>
#define rg(x) x.begin(),x.end()
#define pc(x) __builtin_popcount(x)
#define mems(a,x) memset(a,x,sizeof(a))
#define rep(i,a,b) for(int i=(a);i<=(b);++i)
#define _rep(i,a,b) for(int i=(a);i>=(b);--i)
#define debug(...) fprintf(stderr,__VA_ARGS__)
#define FIO(FILE) freopen(FILE".in","r",stdin),freopen(FILE".out","w",stdout)
using namespace std;
bool __st;
inline int read(){
char c=getchar();int f=1,x=0;
for(;c<48||c>57;c=getchar())if(c=='-') f=-1;
for(;47<c&&c<58;c=getchar()) x=(x<<3)+(x<<1)+(c^48);
return x*f;
}
const int N=1e6+10,mod=998244353;
int n,m,a[N],s[N],ls[N],sz[N],rs[N],mx[N],ans,top;
void dfs(int u){
if(ls[u]) dfs(ls[u]);
if(rs[u]) dfs(rs[u]);
sz[u]=sz[ls[u]]+sz[rs[u]]+1;
mx[u]=max({mx[ls[u]],mx[rs[u]],a[u]});
if(ls[u]&&mx[ls[u]]+a[u]>=sz[ls[u]]+1) ans=max(ans,min(sz[u],mx[ls[u]]+a[u]));
if(rs[u]&&mx[rs[u]]+a[u]>=sz[rs[u]]+1) ans=max(ans,min(sz[u],mx[rs[u]]+a[u]));
if(a[u]>=1) ans=max(ans,1);
}
void solve(){
rep(i,0,n) ls[i]=rs[i]=sz[i]=mx[i]=s[i]=0;top=0;
rep(i,1,n){
int p=0;
while(top&&a[s[top]]>a[i]) p=rs[s[top-1]]=s[top],top--;
ls[i]=p;rs[s[top]]=i;
s[++top]=i;
}
while(top) rs[s[top-1]]=s[top],top--;
ans=0;dfs(rs[0]);
printf("%d\n",ans);
}
void misaka(){
n=read(),m=read();
rep(i,1,n) a[i]=read();
solve();
while(m--){
int k=read(),x,y;
while(k--) x=read(),y=read(),swap(a[x],a[y]);
solve();
}
}
bool __ed;
signed MISAKA(){
#ifdef LOCAL_MSK
atexit([](){
debug("\n%.3lfs ",(double)clock()/CLOCKS_PER_SEC);
debug("%.3lfMB\n",abs(&__st-&__ed)/1024./1024);});
#endif
int T=1;
while(T--) misaka();
return 0;
}
详细
Test #1:
score: 100
Accepted
time: 0ms
memory: 11876kb
input:
5 2 1 2 -2 3 4 1 2 3 1 1 2
output:
2 3 4
result:
ok 3 tokens
Test #2:
score: -100
Wrong Answer
time: 762ms
memory: 40940kb
input:
998546 30 998544 998544 998543 998539 998538 998537 998536 998534 998533 998531 998529 998527 998522 998521 998520 998520 998516 998514 998512 998509 998501 998501 998500 998499 998498 998496 998494 998493 998491 998491 998490 998489 998489 998488 998488 998486 998483 998480 998479 998478 998475 998...
output:
212115 16719 12587 9069 8112 7079 7404 7404 5937 5941 5847 5759 6492 5465 5465 5565 5565 5408 5408 5669 5669 5408 6263 6351 6351 5326 4609 4613 4613 4430 4613
result:
wrong answer 1st words differ - expected: '212114', found: '212115'