답안 #1035166

# 제출 시각 아이디 문제 언어 결과 실행 시간 메모리
1035166 2024-07-26T05:27:12 Z vjudge1 Pipes (CEOI15_pipes) C++
40 / 100
777 ms 62792 KB
#pragma GCC optimize("O3,unroll-loops")        
#include <iostream>
        #include <vector>
        using namespace std;
         
        const int N = 1e5+2;
        struct dsu {
        	int e[N];
        	int find(int &x) { return e[x] < 0 ? x : e[x] = find(e[x]); }
        	bool join(int a, int b) {
        		a = find(a), b = find(b);
        		if (a == b) return false;
        		if (e[a] > e[b]) swap(a, b);
        		e[a] += e[b]; e[b] = a;
        		return true;
        	}
        } d1, d2;
        vector<int> g[N];
        int timer=0;
        void dfs(int at, int par) {
        	d1.e[at]=d2.e[at]=++timer;
        	for(int &to:g[at]) {
        		if(to == par) {
        			par+=N;
        			continue;
        		}
        		if(d2.e[to]) {
        			d1.e[at]=min(d1.e[at], d2.e[to]);		
        		} else {
        			dfs(to, at);
        			d1.e[at]=min(d1.e[at], d1.e[to]);
        		}
        	}
        	if(par>N)par-=N;
        	if(d1.e[at] == d2.e[at] and at!=par) {
        		printf("%d %d\n", at, par);
        	}
        }
        int n, m, u, v;
        int main() {
        	srand(time(0));
         
        	scanf("%d %d", &n, &m);
        	//nt u, v;
        	for(int i = 1;i<N;i++)d1.e[i]=d2.e[i]=-1;
        	for(int i = 0;i<m;i++) {
        		scanf("%d %d", &u, &v);
        		if((d1.join(u, v) || d2.join(u, v))) {
        			g[u].push_back(v);
        			g[v].push_back(u);
        		}
        	}
        	for(int i = 1;i<N;i++)d1.e[i]=d2.e[i]=0;
        	for(int i= 1;i<=n;i++) {
        		if(!d1.e[i]) {
        			dfs(i, i);
        		}
        	}
        }

Compilation message

pipes.cpp: In function 'int main()':
pipes.cpp:43:15: warning: ignoring return value of 'int scanf(const char*, ...)' declared with attribute 'warn_unused_result' [-Wunused-result]
   43 |          scanf("%d %d", &n, &m);
      |          ~~~~~^~~~~~~~~~~~~~~~~
pipes.cpp:47:16: warning: ignoring return value of 'int scanf(const char*, ...)' declared with attribute 'warn_unused_result' [-Wunused-result]
   47 |           scanf("%d %d", &u, &v);
      |           ~~~~~^~~~~~~~~~~~~~~~~
# 결과 실행 시간 메모리 Grader output
1 Correct 2 ms 3420 KB Output is correct
2 Correct 2 ms 3416 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 4 ms 3932 KB Output is correct
2 Correct 4 ms 3676 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 75 ms 3672 KB Output is correct
2 Correct 69 ms 3672 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 110 ms 4204 KB Output is correct
2 Correct 134 ms 3932 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 208 ms 5528 KB Output is correct
2 Runtime error 176 ms 16468 KB Memory limit exceeded
3 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 251 ms 9556 KB Output is correct
2 Runtime error 227 ms 20564 KB Memory limit exceeded
3 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 400 ms 10604 KB Output is correct
2 Runtime error 465 ms 33408 KB Memory limit exceeded
3 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 539 ms 12168 KB Output is correct
2 Runtime error 526 ms 39552 KB Memory limit exceeded
3 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 600 ms 12112 KB Output is correct
2 Runtime error 646 ms 48352 KB Memory limit exceeded
3 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 777 ms 11700 KB Output is correct
2 Runtime error 765 ms 62792 KB Memory limit exceeded
3 Halted 0 ms 0 KB -