답안 #1034730

# 제출 시각 아이디 문제 언어 결과 실행 시간 메모리
1034730 2024-07-25T17:19:44 Z vjudge1 Pipes (CEOI15_pipes) C++17
50 / 100
244 ms 19532 KB
#include <bits/stdc++.h>
using namespace std;

const int N = 70'010;
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) {
	bool ck=0;
	d1.e[at]=d2.e[at]=++timer;
	for(int &to:g[at]) {
		if(to == par and ck==0) {
			ck=1;
			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(d1.e[at] == d2.e[at] and at!=par) {
		cout << at << " " << par << "\n";
	}
}
int main() {
	cin.tie(0)->sync_with_stdio(0);
	cin.exceptions(cin.failbit);
	int n, m;
	cin >> n >> m;
	int u, v;
	for(int i = 1;i<N;i++)d1.e[i]=d2.e[i]=-1;
	for(int i = 0;i<m;i++) {
		cin >> u >> v;
		if(u%2 == 1 and d1.join(u, v) || d2.join(u, v)) {
			g[u].push_back(v);
			g[v].push_back(u);
		}
		else if(d2.join(u, v) || d1.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:46:15: warning: suggest parentheses around '&&' within '||' [-Wparentheses]
   46 |   if(u%2 == 1 and d1.join(u, v) || d2.join(u, v)) {
      |      ~~~~~~~~~^~~~~~~~~~~~~~~~~
pipes.cpp:55:40: warning: iteration 70009 invokes undefined behavior [-Waggressive-loop-optimizations]
   55 |  for(int i = 1;i<=N;i++)d1.e[i]=d2.e[i]=0;
      |                                 ~~~~~~~^~
pipes.cpp:55:17: note: within this loop
   55 |  for(int i = 1;i<=N;i++)d1.e[i]=d2.e[i]=0;
      |                ~^~~
pipes.cpp:55:40: warning: 'void* __builtin_memset(void*, int, long unsigned int)' forming offset [280040, 280043] is out of the bounds [0, 280040] of object 'd2' with type 'dsu' [-Warray-bounds]
   55 |  for(int i = 1;i<=N;i++)d1.e[i]=d2.e[i]=0;
      |                                 ~~~~~~~^~
pipes.cpp:15:7: note: 'd2' declared here
   15 | } d1, d2;
      |       ^~
pipes.cpp:55:32: warning: 'void* __builtin_memset(void*, int, long unsigned int)' forming offset [280040, 280043] is out of the bounds [0, 280040] of object 'd1' with type 'dsu' [-Warray-bounds]
   55 |  for(int i = 1;i<=N;i++)d1.e[i]=d2.e[i]=0;
      |                         ~~~~~~~^~~~~~~~~~
pipes.cpp:15:3: note: 'd1' declared here
   15 | } d1, d2;
      |   ^~
# 결과 실행 시간 메모리 Grader output
1 Correct 1 ms 2652 KB Output is correct
2 Correct 1 ms 2652 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 3 ms 2908 KB Output is correct
2 Correct 3 ms 2832 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 66 ms 5864 KB Output is correct
2 Correct 64 ms 5456 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 107 ms 8368 KB Output is correct
2 Correct 139 ms 9044 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 180 ms 13140 KB Output is correct
2 Correct 153 ms 11348 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Runtime error 244 ms 19532 KB Memory limit exceeded
2 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Runtime error 3 ms 4956 KB Execution killed with signal 11
2 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Runtime error 3 ms 4956 KB Execution killed with signal 11
2 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Runtime error 3 ms 4952 KB Execution killed with signal 11
2 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Runtime error 3 ms 4956 KB Execution killed with signal 11
2 Halted 0 ms 0 KB -