제출 #656029

#제출 시각아이디문제언어결과실행 시간메모리
656029FarbodPort Facility (JOI17_port_facility)C++17
22 / 100
36 ms16460 KiB
/* * In the name of God * * Author: Farbod Doost * Last Modified: Sun, 06 Nov 2022 (12:21:23) * */ #include <iostream> #include <vector> #include <queue> using namespace std; const int N = 2005, mod = 1e9 + 7; int n, l[N], r[N]; vector <int> adj[N]; int d[N]; queue <int> q; long long p(int a, int r) { if (r == 0) return 1; if (r == 1) return a; long long c = p(a, r / 2); return c * c % mod * p(a, r % 2) % mod; } bool f(int i, int j) { if (l[i] < l[j] && l[j] < r[i] && r[i] < r[j]) return 1; if (l[j] < l[i] && l[i] < r[j] && r[j] < r[i]) return 1; return 0; } void bfs(int v) { d[v] = 0, q.push(v); while (!q.empty()) { int u = q.front(); q.pop(); for (auto x: adj[u]) { if (d[x] == -1) d[x] = d[u] + 1, q.push(x); else if (d[x] == d[u]) { cout << 0; exit(0); } } } return; } signed main() { ios_base::sync_with_stdio(false); cin.tie(0); cout.tie(0); cin >> n; for (int i = 0; i < n; i++) cin >> l[i] >> r[i]; for (int i = 0; i < n; i++) for (int j = i + 1; j < n; j++) if (f(i, j)) adj[i].push_back(j), adj[j].push_back(i); for (int i = 0; i < n; i++) d[i] = -1; int ans = 0; for (int i = 0; i < n; i++) { if (d[i] != -1) continue; bfs(i), ans++; } cout << p(2, ans); return 0; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...