当前位置:网站首页>-找树根-
-找树根-
2022-08-03 11:42:00 【-JMY-】
题目描述
一棵树有n个结点,已知树上所有的父子结点关系,请问该树的根是几号结点,哪个结点的子结点最多,该结点有哪些子结点。
输入
第一行,有1个整数n代表结点数量(0<n≤100)
接下来若干行;每行两个结点x和y,表示y是x的孩子(1≤x,y≤n)
输出
第一行输出树根的编号。
第二行输出孩子最多的结点编号(如果有多个结点的子结点都是最多的,则输出编号最大的那个)。
第三行输出第二行求出的孩子最多的结点,有哪些孩子,按照编号从小到大,输出这些孩子的编号,用空格隔开。
样例输入
5 4 1 4 2 1 3 1 5
样例输出
4 4 1 2
参考代码:
#include<bits/stdc++.h>
using namespace std;
int n,a[1005],b[1005],s[1005],k[1005],l[1005],maxn,ip;
int f(int x){
if(s[x]==0)
return x;
return f(s[x]);
}
int main(){
cin>>n;
for(int i=0;i<n-1;i++){
cin>>a[i]>>b[i];
s[b[i]]=a[i];
k[a[i]]++;
}
cout<<f(b[0])<<'\n';
for(int i=0;i<n-1;i++){
if(k[maxn]<k[a[i]]||(k[maxn]<k[a[i]]&&maxn<a[i]))
maxn=a[i];
}
cout<<maxn<<'\n';
for(int i=0;i<n-1;i++){
if(s[b[i]]==maxn){
l[ip]=b[i];
ip++;
}
}
sort(l,l+ip);
for(int i=0;i<ip;i++)
cout<<l[i]<<' ';
return 0;
}
边栏推荐
猜你喜欢
App自动化测试怎么做?实战分享App自动化测试全流程
性能优化|从ping延时看CPU电源管理
JUC(三):锁核心类AQS ing
MySQL - 2059 - Authentication plugin ‘caching_sha2_password‘ cannot be loaded
Dva.js 新手入门指南
距LiveVideoStackCon 2022 上海站开幕还有3天!
深度学习跟踪DLT (deep learning tracker)
Simple implementation of a high-performance clone of Redis using .NET (1)
国内数字藏品与国外NFT主要有以下六大方面的区别
微信小程序获取用户手机号码
随机推荐
深度学习中数据到底要不要归一化?实测数据来说明!
优维低代码:Provider 构件
日常开发写代码原则
Traceback (most recent call last): File
面试突击71:GET 和 POST 有什么区别?
Matlab学习12-图像处理之图像增强
直播弱网优化
劝退背后。
【Mysql】清理binlog日志的方法
hystrix 服务熔断和服务降级
数据库一席谈:打造开源的数据生态,支撑产业数字化浪潮
Objective - C code analysis of the deep and shallow copy
MySQL之json数据操作
Cookie和Session使用
使用.NET简单实现一个Redis的高性能克隆版(一)
【HCIP持续更新】STP协议相关保护机制
[深入浅出]三位数排序
从零开始Blazor Server(6)--基于策略的权限验证
TiKV & TiFlash 加速复杂业务查询丨TiFlash 应用实践
代码分析Objective-C中的深拷贝与浅拷贝