社区讨论
20pts求调,玄关
P11378[GESP202412 七级] 燃烧参与者 2已保存回复 5
讨论操作
快速查看讨论及其快照的属性,并进行相关操作。
- 当前回复
- 5 条
- 当前快照
- 1 份
- 快照标识符
- @mmarc1qm
- 此快照首次捕获于
- 2026/03/03 23:23 4 天前
- 此快照最后确认于
- 2026/03/06 22:05 昨天
CPP
#include<bits/stdc++.h>
using namespace std;
int n;
struct node{
int s,a;
queue<int>nr;
}aa[100001];
int dp[100001],m;
int cnt[100001];
bool cmp(node a,node b){
return a.a<a.a;
}
queue<int> QQ;
int main(){
int ans=0;
cin>>n;
for(int i=1;i<=n;++i){
cin>>m;
aa[i]={i,m,QQ};
}
for(int i=1;i<n;++i){
int u,v;
cin>>u>>v;
if(aa[u].a<aa[v].a){
aa[v].nr.push(u);
}
else if(aa[u].a!=aa[v].a){
aa[u].nr.push(v);
}
}
sort(aa+1,aa+n+1,cmp);
for(int i=1;i<=n;++i){
cnt[aa[i].s]=i;
}
for(int i=1;i<=n;++i){
while(!aa[i].nr.empty()){
dp[i]+=dp[cnt[aa[i].nr.front()]]+1;
aa[i].nr.pop();
}
ans=max(ans,dp[i]+1);
}
cout<<ans;
return 0;
}
回复
共 5 条回复,欢迎继续交流。
正在加载回复...