#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;
int n,m;
vector<int> rednibr;
vector<int> artocki;
vector<vector<int> > v;
int broj=0;
int dfs(int x,int pr,int broj)
{
int minbr=broj;
int granki=0;
int t;
int maxi=0;
rednibr[x]=broj;
for(int i=0;i<v[x].size();i++)
{
if(v[x][i]==pr)
continue;
if(rednibr[v[x][i]])
minbr=min(minbr,rednibr[v[x][i]]);
else
{
int t=dfs(v[x][i],x,broj+1);
minbr=min(minbr,t);
maxi=max(maxi,t);
granki++;
}
}
if(x==0)
{
if(granki>1)
artocki.push_back(x);
}
else
{
if(maxi>=rednibr[x])
artocki.push_back(x);
}
return minbr;
}
int main()
{
cin>>n;
cin>>m;
vector<int> vec;
vector<int> s,e;
v.insert(v.begin(),605000,vec);
int nov=m;
rednibr.insert(rednibr.begin(),605000,0);
for(int i=0;i<m;i++)
{
int a,b;
cin>>a>>b;
a--;
b--;
s.push_back(a);
e.push_back(b);
v[a].push_back(nov);
v[b].push_back(nov);
v[nov].push_back(a);
v[nov].push_back(b);
nov++;
}
for(int i=0;i<n;i++)
{
if(rednibr[i]==0)
dfs(i,-1,1);
}
sort(artocki.begin(),artocki.end());
for(int i=0;i<artocki.size();i++)
{
if(artocki[i]>=m)
cout<<s[artocki[i]-m]+1<<" "<<e[artocki[i]-m]+1<<endl;
}
cout<<endl;
return 0;
}
Compilation message
pipes.cpp: In function 'int dfs(int, int, int)':
pipes.cpp:17:18: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
for(int i=0;i<v[x].size();i++)
~^~~~~~~~~~~~
pipes.cpp:14:9: warning: unused variable 't' [-Wunused-variable]
int t;
^
pipes.cpp: In function 'int main()':
pipes.cpp:72:18: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
for(int i=0;i<artocki.size();i++)
~^~~~~~~~~~~~~~~
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Runtime error |
17 ms |
16868 KB |
Memory limit exceeded (if you are sure your verdict is not MLE, please contact us) |
2 |
Halted |
0 ms |
0 KB |
- |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Runtime error |
27 ms |
18020 KB |
Memory limit exceeded (if you are sure your verdict is not MLE, please contact us) |
2 |
Halted |
0 ms |
0 KB |
- |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Runtime error |
37 ms |
34424 KB |
Execution killed with signal 11 (could be triggered by violating memory limits) |
2 |
Halted |
0 ms |
0 KB |
- |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Runtime error |
34 ms |
33620 KB |
Execution killed with signal 11 (could be triggered by violating memory limits) |
2 |
Halted |
0 ms |
0 KB |
- |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Runtime error |
34 ms |
33560 KB |
Execution killed with signal 11 (could be triggered by violating memory limits) |
2 |
Halted |
0 ms |
0 KB |
- |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Runtime error |
34 ms |
33528 KB |
Execution killed with signal 11 (could be triggered by violating memory limits) |
2 |
Halted |
0 ms |
0 KB |
- |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Runtime error |
34 ms |
33696 KB |
Execution killed with signal 11 (could be triggered by violating memory limits) |
2 |
Halted |
0 ms |
0 KB |
- |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Runtime error |
36 ms |
33536 KB |
Execution killed with signal 11 (could be triggered by violating memory limits) |
2 |
Halted |
0 ms |
0 KB |
- |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Runtime error |
33 ms |
33628 KB |
Execution killed with signal 11 (could be triggered by violating memory limits) |
2 |
Halted |
0 ms |
0 KB |
- |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Runtime error |
35 ms |
33528 KB |
Execution killed with signal 11 (could be triggered by violating memory limits) |
2 |
Halted |
0 ms |
0 KB |
- |