第4届CCCC字符串大赛 L2-3深入虎穴

/*题解详见公众号文章,最底扫码关注*/

#include<bits/stdc++.h>
//#include <iostream>
#define ll long long
#define mem(a,b) memset(a,b,sizeof(a))
#define sss(x,y) scanf("%x",&y)
using namespace std;
const int maxn = 1e5 + 5;
const double gold = (1 + sqrt(5)) / 2.0;
const int inf = 0x3f3f3f;
const int inff = 0x7fffffff;

vector<int>v[maxn];
int ans = 1;
int maxx = -1;

int in[maxn];
void dfs(int pos, int cnt)
{
if (v[pos].size() == 0) {
if (maxx < cnt)
{
maxx = cnt;
ans = pos;
}
}
for (int i = 0; i < v[pos].size(); i++) {
dfs(v[pos][i], cnt + 1);
}
}

int main()
{
//freopen("D:\\in.txt", "r", stdin);
//freopen("D:\\out.txt", "w", stdout);

//while (true)//方便测试 提交时记得注释
{
int t;
cin >> t;
mem(in, 0);
for (int i = 1; i <= t; i++) {
int k;
scanf("%d", &k);
int t;
for (int j = 0; j < k; j++) {
scanf("%d", &t);
in[t]++;
v[i].push_back(t);
}
}
for (int i = 1; i <= t; i++) {
if (in[i] == 0) {
dfs(i, 0);
}
}
//cout << maxx << endl;
cout << ans << endl;
}
//fclose(stdin);
//fclose(stdout);
system("pause");
return 0;
}

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值