Submission #46961

# Submission time Handle Problem Language Result Execution time Memory
46961 2018-04-25T11:32:35 Z iletavcioski Pipes (CEOI15_pipes) C++17
0 / 100
37 ms 34424 KB
#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++)
                 ~^~~~~~~~~~~~~~~
# Verdict Execution time Memory 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 -
# Verdict Execution time Memory 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 -
# Verdict Execution time Memory 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 -
# Verdict Execution time Memory 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 -
# Verdict Execution time Memory 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 -
# Verdict Execution time Memory 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 -
# Verdict Execution time Memory 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 -
# Verdict Execution time Memory 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 -
# Verdict Execution time Memory 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 -
# Verdict Execution time Memory 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 -