Submission #46960

# Submission time Handle Problem Language Result Execution time Memory
46960 2018-04-25T11:31:22 Z iletavcioski Pipes (CEOI15_pipes) C++17
0 / 100
330 ms 65536 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(),1000000,vec);
    int nov=m;
    rednibr.insert(rednibr.begin(),1000000,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 26 ms 27768 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 28876 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 330 ms 65536 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 55 ms 55292 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 54 ms 55356 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 55 ms 55260 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 54 ms 55364 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 55 ms 55268 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 53 ms 55204 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 54 ms 55164 KB Execution killed with signal 11 (could be triggered by violating memory limits)
2 Halted 0 ms 0 KB -