社区讨论
求条
学术版参与者 2已保存回复 4
讨论操作
快速查看讨论及其快照的属性,并进行相关操作。
- 当前回复
- 4 条
- 当前快照
- 1 份
- 快照标识符
- @mhjtlypg
- 此快照首次捕获于
- 2025/11/04 08:18 4 个月前
- 此快照最后确认于
- 2025/11/04 08:18 4 个月前
我的P1656代码没输出,求条玄关
CPP#include <bits/stdc++.h>
using namespace std;
int n,m,low[150],dfn[150],father[150],idx,cnt;
vector <int> q[150];
pair <int,int> gb[5000];
void tarjan(int u,int fa)
{
father[u] = fa;
low[u] = dfn[u] = ++idx;
for (int i = 0;i < q[u].size();i++)
{
int v = q[u][i];
if (!dfn[v])
{
tarjan(v,u);
}
low[u] = min(low[u],low[v]);
if (low[v] > dfn[u])
{
gb[cnt].first = min(u,v);
gb[cnt].second = max(u,v);
cnt++;
}
else if (v != fa)
{
low[u] = min(low[u], dfn[v]);
}
}
}
int main()
{
cin >> n >> m;
for (int i = 0;i < m;i++)
{
int a,b;
cin >> a >> b;
q[a].push_back(b);
q[b].push_back(a);
}
for (int i = 1;i <= n;i++)
{
if (!dfn[i])
{
tarjan(i,-1);
}
}
sort(gb,gb + cnt);
for (int i = 0;i < cnt;i++)
{
cout << gb[i].first << ' ' << gb[i].second << endl;
}
return 0;
}
回复
共 4 条回复,欢迎继续交流。
正在加载回复...