이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
/* Author : Tr3nity */
#include<bits/stdc++.h>
using namespace std;
#define ll long long int
#define mod1 (1000000000+7)
#define mod (998244353)
#define pb push_back
#define all(x) x.begin(), x.end()
#define mp make_pair
#define en cout << '\n'
const int N = 1e6+100, M = 1e5+10, K = 18;
struct dp{
int val, dist;
};
int n, d;
vector<int> g[N];
dp a[N];
void update(int v, int x, int dep){
if(x > a[v].val){
a[v].val = x;
a[v].dist = dep;
}else if(x == a[v].val && dep > a[v].dist){
a[v].dist = dep;
}
}
void dfs(int v){
int sum = 0, small = 0, biggest_small = -1, smallest_big = d;
for(int u: g[v]){
dfs(u);
sum += a[u].val;
if(a[u].dist < (d+1)/2){
small++;
if(biggest_small == -1 || a[biggest_small].dist < a[u].dist){
biggest_small = u;
}
}else if(d % 2 == 0 && a[u].dist == d / 2){
biggest_small = u;
}
if((d+1)/2 <= a[u].dist){
smallest_big = min(smallest_big, a[u].dist);
}
}
if(g[v].size() == 0){
a[v].val = 1, a[v].dist = 1;
return;
}
update(v, sum - small + (smallest_big == d), (smallest_big == d ? 0 : smallest_big));
if(biggest_small != -1)
update(v, sum - small + !(a[biggest_small].dist == d/2 && d%2==0), a[biggest_small].dist);
a[v].dist++;
}
void solve(){
cin >> n >> d;
for(int i = 1; i <= n-1; ++i){
int x; cin >> x;
g[x].pb(i);
}
for(int i = 0; i < n; ++i) a[i].val = 0, a[i].dist = d;
dfs(0);
cout << a[0].val;
}
int main(){
cin.tie(0); ios::sync_with_stdio(0);
int tt = 1, aa;
// freopen("in.txt", "r", stdin);
// freopen("out.txt", "w", stdout);
// cin >> tt;aa=tt;
while(tt--){
solve();
}
cerr<<"time taken : "<<(float)clock()/CLOCKS_PER_SEC<<" seconds\n";
return 0;
}
컴파일 시 표준 에러 (stderr) 메시지
catinatree.cpp: In function 'int main()':
catinatree.cpp:72:15: warning: unused variable 'aa' [-Wunused-variable]
72 | int tt = 1, aa;
| ^~
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |