답안 #1035123

# 제출 시각 아이디 문제 언어 결과 실행 시간 메모리
1035123 2024-07-26T05:03:03 Z vjudge1 Pipes (CEOI15_pipes) C++14
40 / 100
755 ms 65536 KB
    #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:42:11: warning: ignoring return value of 'int scanf(const char*, ...)' declared with attribute 'warn_unused_result' [-Wunused-result]
   42 |      scanf("%d %d", &n, &m);
      |      ~~~~~^~~~~~~~~~~~~~~~~
pipes.cpp:46:12: warning: ignoring return value of 'int scanf(const char*, ...)' declared with attribute 'warn_unused_result' [-Wunused-result]
   46 |       scanf("%d %d", &u, &v);
      |       ~~~~~^~~~~~~~~~~~~~~~~
# 결과 실행 시간 메모리 Grader output
1 Correct 2 ms 3416 KB Output is correct
2 Correct 1 ms 3416 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 4 ms 3932 KB Output is correct
2 Correct 3 ms 3676 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 64 ms 3704 KB Output is correct
2 Correct 63 ms 3672 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 105 ms 4180 KB Output is correct
2 Correct 146 ms 3932 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 188 ms 5456 KB Output is correct
2 Runtime error 158 ms 19028 KB Memory limit exceeded
3 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 250 ms 9556 KB Output is correct
2 Runtime error 219 ms 24908 KB Memory limit exceeded
3 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 375 ms 10580 KB Output is correct
2 Runtime error 392 ms 41296 KB Memory limit exceeded
3 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 495 ms 12260 KB Output is correct
2 Runtime error 484 ms 49540 KB Memory limit exceeded
3 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 591 ms 12116 KB Output is correct
2 Runtime error 628 ms 61008 KB Memory limit exceeded
3 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 755 ms 11688 KB Output is correct
2 Runtime error 752 ms 65536 KB Memory limit exceeded
3 Halted 0 ms 0 KB -