AcWing:單鏈表與雙鏈表(y總純陣列實現)
阿新 • • 發佈:2020-11-04
用資料模擬單鏈表與雙鏈表
單鏈表
題目:
#include <iostream> using namespace std; const int N = 100010; // head 表示頭結點的下標 // e[i] 表示節點i的值 // ne[i] 表示節點i的next指標是多少 // idx 儲存當前已經用到了哪個點 int head, e[N], ne[N], idx; // 初始化 void init() { head = -1; idx = 0; } // 將x插到頭結點,第k個插入的數下標是k-1 void add_to_head(int x) { e[idx] = x, ne[idx] = head, head = idx ++ ; } // 將x插到下標是k的點後面 void add(int k, int x) { e[idx] = x, ne[idx] = ne[k], ne[k] = idx ++ ; } // 將下標是k的點後面的點刪掉 void remove(int k) { ne[k] = ne[ne[k]]; } int main() { int m; cin >> m; init(); while (m -- ) { int k, x; char op; cin >> op; if (op == 'H') { cin >> x; add_to_head(x); } else if (op == 'D') { cin >> k; if (!k) head = ne[head]; else remove(k - 1); } else { cin >> k >> x; add(k - 1, x); } } for (int i = head; i != -1; i = ne[i]) cout << e[i] << ' '; cout << endl; return 0; }
雙鏈表
題目:
#include <iostream> using namespace std; const int N = 100010; int m; int e[N], l[N], r[N], idx; // 在節點a的右邊插入一個數x void insert(int a, int x) { e[idx] = x; l[idx] = a, r[idx] = r[a]; l[r[a]] = idx, r[a] = idx ++ ; } // 刪除節點a void remove(int a) { l[r[a]] = l[a]; r[l[a]] = r[a]; } int main() { cin >> m; // 0是左端點,1是右端點 r[0] = 1, l[1] = 0; idx = 2; while (m -- ) { string op; cin >> op; int k, x; if (op == "L") { cin >> x; insert(0, x); } else if (op == "R") { cin >> x; insert(l[1], x); } else if (op == "D") { cin >> k; remove(k + 1); } else if (op == "IL") { cin >> k >> x; insert(l[k + 1], x); } else { cin >> k >> x; insert(k + 1, x); } } for (int i = r[0]; i != 1; i = r[i]) cout << e[i] << ' '; cout << endl; return 0; }