105262024-04-04 16:25:43111K-léptű ősökcpp17Elfogadva 100/1001.011s242204 KiB
#include<bits/stdc++.h>
using namespace std;

#define int long long

signed main(){
	ios::sync_with_stdio(false);
	cin.tie(nullptr);
	int N,K;
	cin>>N>>K;
	vector<vector<int>>g(N);
	for(int i=0;i<N-1;i++){
		int a,b;
		cin>>a>>b;
		g[a].push_back(b);
		g[b].push_back(a);
	}
	vector<int>ans(N,-1),s;
	auto dfs=[&](auto self,int i,int p)->void{
		if(s.size()>=K){
			ans[i]=s[s.size()-K];
		}
		s.push_back(i);
		for(int j:g[i]){
			if(j==p){
				continue;
			}
			self(self,j,i);
		}
		s.pop_back();
	};
	dfs(dfs,0,-1);
	for(int i=0;i<N;i++){
		cout<<ans[i]<<' ';
	}
	cout<<'\n';
	return 0;
}
RészfeladatÖsszpontTesztVerdiktIdőMemória
subtask10/0
1Elfogadva3ms2108 KiB
subtask225/25
2Elfogadva3ms2308 KiB
3Elfogadva3ms2532 KiB
4Elfogadva3ms2700 KiB
5Elfogadva3ms2916 KiB
6Elfogadva3ms2960 KiB
7Elfogadva3ms3248 KiB
8Elfogadva3ms3284 KiB
9Elfogadva4ms3740 KiB
10Elfogadva4ms4048 KiB
11Elfogadva4ms4132 KiB
subtask316/16
12Elfogadva28ms11700 KiB
13Elfogadva52ms25128 KiB
14Elfogadva61ms25876 KiB
15Elfogadva48ms25548 KiB
16Elfogadva56ms27588 KiB
17Elfogadva57ms29368 KiB
18Elfogadva56ms30508 KiB
subtask459/59
19Elfogadva68ms34964 KiB
20Elfogadva97ms43708 KiB
21Elfogadva109ms41672 KiB
22Elfogadva126ms51356 KiB
23Elfogadva128ms55844 KiB
24Elfogadva141ms51600 KiB
25Elfogadva337ms92888 KiB
26Elfogadva333ms103048 KiB
27Elfogadva607ms187544 KiB
28Elfogadva625ms187036 KiB
29Elfogadva820ms211904 KiB
30Elfogadva808ms219948 KiB
31Elfogadva748ms227728 KiB
32Elfogadva642ms242204 KiB
33Elfogadva1.011s181444 KiB