Bài giảng Thuật toán ứng dụng - Chương 6, Phần 1: Tarjan dfs algorithm for finding bridges and articulation points - Phạm Quang Dũng

Sample code #include using namespace std; const int N = 10000; int n,m; vector A[N]; bool visited[N]; int num[N]; int low[N]; int t; vector<> > bridges; void input(){ ios_base::sync_with_stdio(0); cin.tie(0); cin >> n >> m; for(int i = 1; i <= m; i++){ int u,v; cin >> u >> v; A[u].push_back(v); A[v].push_back(u); } }Sample code 20 void dfs(int s, int ps){ // DFS from s with ps is the parent of s in the DFS tree t++; num[s] = t; low[s] = num[s]; visited[s] = true; for(int i = 0;i < A[s].size(); i++){ int v = A[s][i]; if(v == ps) continue; if(visited[v]){ low[s] = min(low[s],num[v]); }else{ dfs(v,s); low[s] = min(low[s],low[v]); if(low[v] > num[s]){ // discover a bridge (s,v) bridges.push_back(make_pair(s,v)); } } } }

pdf21 trang | Chia sẻ: hachi492 | Ngày: 06/01/2022 | Lượt xem: 406 | Lượt tải: 0download
Bạn đang xem trước 20 trang tài liệu Bài giảng Thuật toán ứng dụng - Chương 6, Phần 1: Tarjan dfs algorithm for finding bridges and articulation points - Phạm Quang Dũng, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
Tarjan DFS algorithm for finding Bridges and Articulation Points THUẬT TOÁN ỨNG DỤNG 1 Phạm Quang Dũng Bộ môn KHMT dungpq@soict.hust.edu.vn Duyệt theo chiều sâu  Cây DFS  DFS xuất phát từ một đỉnh cho phép thăm các đỉnh con cháu của nó trên cây DFS  Cấu trúc dữ liệu duy trì  num[v]: thời điểm đỉnh v được thăm  low[v]: giá trị num nhỏ nhất của các đỉnh x sao cho có cạnh ngược (u,x) với u là 1 đỉnh con cháu nào đó của v 2 DFS(6) 3 1 6 3 2 8 5 9 7 4 DFS(6) 4 6 num[6] = 1, low[6] = 1 DFS(6) 5 1 6 num[6] = 1, low[6] = 1 num[1] = 2, low[[1] = 2 DFS(6) 6 1 6 3 num[6] = 1, low[6] = 1 num[1] = 2, low[[1] = 2 num[3] = 3, low[3] = 3 DFS(6) 7 1 6 3 2 num[6] = 1, low[6] = 1 num[1] = 2, low[[1] = 2 num[3] = 3, low[3] = 3 num[2] = 4, low[2] = 4 DFS(6) 8 1 6 3 2 8 num[6] = 1, low[6] = 1 num[1] = 2, low[[1] = 2 num[3] = 3, low[3] = 3 num[2] = 4, low[2] = 4 num[8] = 5, low[8] = 5 DFS(6) 9 1 6 3 2 8 5 num[6] = 1, low[6] = 1 num[1] = 2, low[[1] = 2 num[3] = 3, low[3] = 3 num[2] = 4, low[2] = 4 num[8] = 5, low[8] = 5 num[5] = 6, low[5] = 6 DFS(6) 10 1 6 3 2 8 5 9 num[6] = 1, low[6] = 1 num[1] = 2, low[[1] = 2 num[3] = 3, low[3] = 3 num[2] = 4, low[2] = 4 num[8] = 5, low[8] = 5 num[5] = 6, low[5] = 6 num[9] = 7, low[9] = 7 DFS(6) 11 1 6 3 2 8 5 9 num[6] = 1, low[6] = 1 num[1] = 2, low[[1] = 2 num[3] = 3, low[3] = 3 num[2] = 4, low[2] = 4 num[8] = 5, low[8] = 5 num[5] = 6, low[5] = 6 num[9] = 7, low[9] = num[2] = 4 DFS(6) 12 1 6 3 2 8 5 9 7 num[6] = 1, low[6] = 1 num[1] = 2, low[[1] = 2 num[3] = 3, low[3] = 3 num[2] = 4, low[2] = 4 num[8] = 5, low[8] = 5 num[5] = 6, low[5] = 6 num[9] = 7, low[9] = num[2] = 4 num[7] = 8, low[7] = 8 DFS(6) 13 1 6 3 2 8 5 9 7 num[6] = 1, low[6] = 1 num[1] = 2, low[[1] = 2 num[3] = 3, low[3] = 3 num[2] = 4, low[2] = 4 num[8] = 5, low[8] = 5 num[5] = 6, low[5] = 6 num[9] = 7, low[9] = num[2] = 4 num[7] = 8, low[7] = num[8] = 5 DFS(6) 14 1 6 3 2 8 5 9 7 num[6] = 1, low[6] = 1 num[1] = 2, low[[1] = 2 num[3] = 3, low[3] = 3 num[2] = 4, low[2] = 4 num[8] = 5, low[8] = 5 num[5] = 6, low[5] = low[9] = 4 num[9] = 7, low[9] = num[2] = 4 num[7] = 8, low[7] = num[8] = 5 DFS(6) 15 1 6 3 2 8 5 9 7 num[6] = 1, low[6] = 1 num[1] = 2, low[[1] = 2 num[3] = 3, low[3] = 3 num[2] = 4, low[2] = 4 num[8] = 5, low[8] = low[5] = 4 num[5] = 6, low[5] = low[9] = 4 num[9] = 7, low[9] = num[2] = 4 num[7] = 8, low[7] = num[8] = 5 DFS(6) 16 1 6 3 2 8 5 9 7 num[6] = 1, low[6] = 1 num[1] = 2, low[[1] = 2 num[3] = 3, low[3] = num[6] = 1 num[2] = 4, low[2] = 4 num[8] = 5, low[8] = low[5] = 4 num[5] = 6, low[5] = low[9] = 4 num[9] = 7, low[9] = num[2] = 4 num[7] = 8, low[7] = num[8] = 5 DFS(6) 17 1 6 3 2 8 5 9 7 num[6] = 1, low[6] = 1 num[1] = 2, low[[1] = low[3] = 1 num[3] = 3, low[3] = num[6] = 1 num[2] = 4, low[2] = 4 num[8] = 5, low[8] = low[5] = 4 num[5] = 6, low[5] = low[9] = 4 num[9] = 7, low[9] = num[2] = 4 num[7] = 8, low[7] = num[8] = 5 DFS(6) 18 1 6 3 2 8 5 9 7 4 num[6] = 1, low[6] = 1 num[1] = 2, low[[1] = low[3] = 1 num[3] = 3, low[3] = num[6] = 1 num[2] = 4, low[2] = 4 num[8] = 5, low[8] = low[5] = 4 num[5] = 6, low[5] = low[9] = 4 num[9] = 7, low[9] = num[2] = 4 num[7] = 8, low[7] = num[8] = 5 num[4] = 9, low[4] = 9 Sample code 19 #include using namespace std; const int N = 10000; int n,m; vector A[N]; bool visited[N]; int num[N]; int low[N]; int t; vector > bridges; void input(){ ios_base::sync_with_stdio(0); cin.tie(0); cin >> n >> m; for(int i = 1; i <= m; i++){ int u,v; cin >> u >> v; A[u].push_back(v); A[v].push_back(u); } } Sample code 20 void dfs(int s, int ps){ // DFS from s with ps is the parent of s in the DFS tree t++; num[s] = t; low[s] = num[s]; visited[s] = true; for(int i = 0;i < A[s].size(); i++){ int v = A[s][i]; if(v == ps) continue; if(visited[v]){ low[s] = min(low[s],num[v]); }else{ dfs(v,s); low[s] = min(low[s],low[v]); if(low[v] > num[s]){ // discover a bridge (s,v) bridges.push_back(make_pair(s,v)); } } } } Sample code 21 void init(){ for(int v = 1; v <= n; v++) visited[v] = false; } void solve(){ init(); t = 0; for(int s = 1; s <= n; s++){ if(!visited[s]){ dfs(s,-1); } } cout << "bridges = "; for(int i = 0; i < bridges.size(); i++){ cout << "(" << bridges[i].first << "," << bridges[i].second << ") "; } } int main(){ input(); solve(); }

Các file đính kèm theo tài liệu này:

  • pdfbai_giang_thuat_toan_ung_dung_chuong_6_phan_1_tarjan_dfs_alg.pdf