結果
問題 | No.19 ステージの選択 |
ユーザー | btk |
提出日時 | 2015-05-07 01:49:53 |
言語 | C++11 (gcc 11.4.0) |
結果 |
AC
|
実行時間 | 2 ms / 5,000 ms |
コード長 | 1,604 bytes |
コンパイル時間 | 825 ms |
コンパイル使用メモリ | 95,344 KB |
実行使用メモリ | 5,376 KB |
最終ジャッジ日時 | 2024-06-02 12:29:02 |
合計ジャッジ時間 | 1,656 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge4 |
(要ログイン)
テストケース
テストケース表示入力 | 結果 | 実行時間 実行使用メモリ |
---|---|---|
testcase_00 | AC | 2 ms
5,248 KB |
testcase_01 | AC | 2 ms
5,376 KB |
testcase_02 | AC | 2 ms
5,376 KB |
testcase_03 | AC | 2 ms
5,376 KB |
testcase_04 | AC | 2 ms
5,376 KB |
testcase_05 | AC | 2 ms
5,376 KB |
testcase_06 | AC | 1 ms
5,376 KB |
testcase_07 | AC | 1 ms
5,376 KB |
testcase_08 | AC | 1 ms
5,376 KB |
testcase_09 | AC | 2 ms
5,376 KB |
testcase_10 | AC | 1 ms
5,376 KB |
testcase_11 | AC | 2 ms
5,376 KB |
testcase_12 | AC | 1 ms
5,376 KB |
testcase_13 | AC | 2 ms
5,376 KB |
testcase_14 | AC | 1 ms
5,376 KB |
testcase_15 | AC | 1 ms
5,376 KB |
testcase_16 | AC | 1 ms
5,376 KB |
testcase_17 | AC | 1 ms
5,376 KB |
testcase_18 | AC | 1 ms
5,376 KB |
testcase_19 | AC | 1 ms
5,376 KB |
testcase_20 | AC | 1 ms
5,376 KB |
testcase_21 | AC | 2 ms
5,376 KB |
testcase_22 | AC | 2 ms
5,376 KB |
testcase_23 | AC | 2 ms
5,376 KB |
ソースコード
#include<iostream> #include<fstream> #include<sstream> #include<string> #include<cstdio> #include<cstdlib> #include<cstring> #include<ctime> #include<stack> #include<queue> #include<set> #include<map> #include<vector> #include<list> #include<algorithm> #include<utility> #include<complex> #include<functional> using namespace std; bool used[100]; int p[100]; int num = 0; vector<list<int>> good; vector<list<int>> bad; int level[100]; void dfs(int s){ used[s] = true; for(auto v :good[s]) { if (used[v])continue; dfs(v); } p[num++] = s; } int bfs(int s){ int res = level[s]; int mini = res; int cnt = 1; queue<int> que; que.push(s); used[s] = true; if (bad[s].size() == 0)return level[s] * 2; while (que.empty() == false){ auto v = que.front(); que.pop(); //cout << v << " "; for(auto u: bad[v]) { if (used[u])continue; used[u] = true; que.push(u); res += level[u]; mini = min(mini, level[u]); cnt++; } } if (cnt > 1)res += mini; // cout << endl; return res; } int main(void){ int N,s,sum=0; cin >> N; good.resize(N); bad.resize(N); for (int i = 0; i < N; i++) { used[i] = false; cin >> level[i] >> s; s--; if (s != i){ good[s].push_back(i); bad[i].push_back(s); } } for (int i = 0; i < N; i++) { if (used[i])continue; dfs(i); } reverse(p, p + N); for (int i = 0; i < N; i++) { used[i] = false; // cout << p[i] << " "; } //cout << endl; for (int i = 0; i < N; i++) { if (used[p[i]])continue; sum += bfs(p[i]); } cout << sum / 2 ; if (sum & 1)cout << ".5"; else cout << ".0"; cout << endl; return 0; }