# UVa .821 Page Hopping [**題目連結**](https://onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem&problem=762) ## **Floyd Warshell** ```cpp= #include<iostream> #include<vector> #include<algorithm> #include<iomanip> using namespace std; int main() { int Case = 1, a, b; while(true) { vector<vector<int>> len(101, vector<int> (101, 1e9)); vector<int> node; vector<bool> exit(101, false); double sum = 0; for(int i = 1 ; i <= 100 ; i++) len[i][i] = 0; while(cin >> a >> b && a != 0 && b != 0) { len[a][b] = 1; if(!exit[a]) node.push_back(a); if(!exit[b]) node.push_back(b); exit[a] = exit[b] = true; } if(node.empty()) break; sort(node.begin(), node.end()); int n = node.back(); for(int k = 1 ; k <= n ; k++) //Floyd for(int i = 1 ; i <= n ; i++) for(int j = 1 ; j <= n ; j++) if(exit[i] && exit[j] && exit[k]) len[i][j] = min(len[i][j], len[i][k] + len[k][j]); for(int i = 1 ; i <= n ; i++) { for(int j = 1 ; j <= n ; j++) { if(exit[i] && exit[j] && i != j) sum += len[i][j]; } } cout << "Case " << Case << ": average length between pages = "; cout << fixed << setprecision(3) << sum / (node.size() * (node.size() - 1)) << " clicks\n"; Case++; } return 0; } ``` ## **BFS** ```cpp= #include<iostream> #include<queue> #include<vector> #include<algorithm> #include<iomanip> using namespace std; void bfs(int i, vector<vector<int>> &Map, vector<int> &path) { queue<int> q; q.push(i); path[i] = 0; while(!q.empty()) { int now = q.front(); q.pop(); for(int i : Map[now]) { if(path[i] == -1) { path[i] = path[now] + 1; q.push(i); } } } } int main() { int Case = 1; while(true) { vector<vector<int>> Map(101, vector<int>{}); vector<int> node; vector<bool> exit(101, false); int a, b; double sum = 0; while(cin >> a >> b && a != 0 && b != 0) { if(!exit[a]) node.push_back(a); if(!exit[b]) node.push_back(b); exit[a] = exit[b] = true; Map[a].push_back(b); } if(node.empty()) break; sort(node.begin(), node.end()); for(int i : node) { vector<int> path(node.back() + 1, -1); bfs(i, Map, path); for(int i = 1 ; i <= path.size() ; i++) if(exit[i]) sum += path[i]; } cout << "Case " << Case << ": average length between pages = "; cout << fixed << setprecision(3) << sum / (node.size() * ( node.size() - 1 )) << " clicks\n"; Case++; } } ```