社区讨论
蜜汁MLE??(玄关求解惑)
P3478[POI 2008] STA-Station参与者 4已保存回复 7
讨论操作
快速查看讨论及其快照的属性,并进行相关操作。
- 当前回复
- 7 条
- 当前快照
- 1 份
- 快照标识符
- @mlhowsem
- 此快照首次捕获于
- 2026/02/11 15:10 上周
- 此快照最后确认于
- 2026/02/11 15:45 上周
这是MLE的代码,但为什么将N改为2*N明明占内存更大却过了??
CPP#include<bits/stdc++.h>
#define int long long
#define ull unsigned long long
const int N=1e6+9;
#define el "\n"
using namespace std;
int n;
int siz[N];
int head[N];
int cnt;
int deep[N];
int aa[N];
int ans;
int anss;
struct node
{
int to,nxt;
}a[N];//原本应该为2*N
void add(int x,int y)
{
a[++cnt].nxt=head[x];
head[x]=cnt;
a[cnt].to=y;
}
void dfs(int now,int fa)
{
siz[now]=1;
deep[now]=deep[fa]+1;
for(int i=head[now];i;i=a[i].nxt)
{
int y=a[i].to;
if(y==fa) continue;
dfs(y,now);
siz[now]+=siz[y];
}
}
void dfss(int now,int fa)
{
for(int i=head[now];i;i=a[i].nxt)
{
int y=a[i].to;
if(y==fa) continue;
aa[y]=aa[now]+n-2*siz[y];
dfss(y,now);
}
}
signed main()
{
ios::sync_with_stdio(0);
cin.tie(0);
cout.tie(0);
cin >> n;
for(int i=1;i < n;i++)
{
int x,y;
cin >> x >> y;
add(x,y);
add(y,x);
}
dfs(1,0);
for(int i=1;i <= n;i++) aa[1]+=deep[i];
dfss(1,0);
for(int i=1;i <= n;i++) if(ans<aa[i]) ans=aa[i],anss=i;
cout<<anss;
return 0;
}
/*
priority_queue<int>a;
*/
回复
共 7 条回复,欢迎继续交流。
正在加载回复...