제출 #1268130

#제출 시각아이디문제언어결과실행 시간메모리
126813029ChuManhTich관광 (NOI14_sightseeing)C++20
15 / 25
185 ms22512 KiB
#include<bits/stdc++.h> using namespace std; #define NAME "FOX" #define FOR(i, a, b) for(int i = a; i <= b; i++) #define FOD(i, a, b) for(int i = a; i >= b; i--) #define ll long long #define ii pair<int, int> #define fi first #define se second #define fastIO ios_base::sync_with_stdio(false); \ cin.tie(NULL); \ cout.tie(NULL); #define BIT(x, i) ((x >> i) & 1) #define ALL(x) x.begin(), x.end() const int maxn = 5e5 + 11; const int LOGN = 20; const int MOD = 1e9 + 7; int n, m, q; struct Edge { int u, v, w; bool operator < (Edge &o) { return w > o.w; } } edge[maxn]; struct DSU { int N, p[maxn], sz[maxn]; void init(int n) { N = n; FOR(i, 1, N) p[i] = i, sz[i] = 1; } int find_set(int u) { return (u == p[u]) ? u : p[u] = find_set(p[u]); } bool united(int u, int v) { u = find_set(u); v = find_set(v); if(u == v) return false; if(sz[u] < sz[v]) swap(u, v); sz[u] += sz[v]; p[v] = u; return true; } }; vector<ii> adj[maxn]; int res[maxn]; void dfs(int u, int par, int qua) { for(ii p : adj[u]) { int v = p.fi, w = p.se; if (v == par) continue; int newqua = min(qua, w); res[v] = newqua; dfs(v, u, newqua); } } signed main() { if(fopen(NAME".INP", "r")) { freopen(NAME".INP", "r", stdin); freopen(NAME".OUT", "w", stdout); } fastIO; cin >> n >> m >> q; FOR(i, 1, m) { int u, v, w; cin >> u >> v >> w; edge[i] = {u, v, w}; } DSU dsu; dsu.init(n + 5); sort(edge + 1, edge + m + 1); int cnt = 0; FOR(i, 1, m) { if(cnt >= n - 1) break; int u = edge[i].u, v = edge[i].v, w = edge[i].w; if(dsu.united(u, v)) { cnt++; adj[u].push_back({v, w}); adj[v].push_back({u, w}); } } FOR(i, 1, n) res[i] = INT_MAX; dfs(1, 0, INT_MAX); FOR(i, 1, q) { int x; cin >> x; cout << res[x] << "\n"; } return 0; } /* 4 4 2 1 2 10 1 3 30 2 4 20 3 4 5 3 4 */

컴파일 시 표준 에러 (stderr) 메시지

sightseeing.cpp: In function 'int main()':
sightseeing.cpp:69:16: warning: ignoring return value of 'FILE* freopen(const char*, const char*, FILE*)' declared with attribute 'warn_unused_result' [-Wunused-result]
   69 |         freopen(NAME".INP", "r", stdin);
      |         ~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~
sightseeing.cpp:70:16: warning: ignoring return value of 'FILE* freopen(const char*, const char*, FILE*)' declared with attribute 'warn_unused_result' [-Wunused-result]
   70 |         freopen(NAME".OUT", "w", stdout);
      |         ~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...