實現乙個雙鏈表,雙鏈表初始為空,支援5種操作:
(1) 在最左側插入乙個數;
(2) 在最右側插入乙個數;
(3) 將第k個插入的數刪除;
(4) 在第k個插入的數左側插入乙個數;
(5) 在第k個插入的數右側插入乙個數
現在要對該鍊錶進行m次操作,進行完所有操作後,從左到右輸出整個鍊錶。
注意:題目中第k個插入的數並不是指當前鍊錶的第k個數。例如操作過程中一共插入了n個數,則按照插入的時間順序,這n個數依次為:第1個插入的數,第2個插入的數,…第n個插入的數。
輸入格式
第一行包含整數m,表示操作次數。
接下來m行,每行包含乙個操作命令,操作命令可能為以下幾種:
(1) 「l x」,表示在鍊錶的最左端插入數x。
(2) 「r x」,表示在鍊錶的最右端插入數x。
(3) 「d k」,表示將第k個插入的數刪除。
(4) 「il k x」,表示在第k個插入的數左側插入乙個數。
(5) 「ir k x」,表示在第k個插入的數右側插入乙個數。
輸出格式
共一行,將整個鍊錶從左到右輸出。
資料範圍
1≤m≤100000
所有操作保證合法。
輸入樣例:10
r 7d 1
l 3il 2 10
d 3il 2 7
l 8r 9
il 4 7
ir 2 2
輸出樣例:
8 7 7 3 2 9
#include
#include
using
namespace std;
const
int n =
1e5+5;
int r[n]
, l[n]
, val[n]
, len;
void init (
)//在第k號節點右邊插入
void
add(
int k,
int x)
//刪除第k個點
void
remove
(int k)
int n, k, x;
char str[3]
;int
main()
else
if(str[0]
=='l'
)else
if(str[0]
=='r'
)else
if(str[0]
=='i'
&& str[1]
=='r'
)else
if(str[0]
=='i'
&& str[1]
=='l')}
//從左往右輸出
for(
int j = r[0]
; j !=
1; j = r[j]
)return0;
}
資料結構 雙鏈表
typedef struct nodenode 雙鏈表的根節點的bwd指標指向雙鏈表的最後乙個節點,fwd指標指向雙鏈表的第乙個節點,雙鏈表的value欄位為空 以下程式是將乙個值插入到乙個有序的雙鏈表中,如果鍊錶中已經有和該值相同的節點則不插入 include include typedef st...
資料結構 雙鏈表
目標 掌握雙鏈表的資料結構 來看看什麼是雙鏈表吧 雙鏈表與單鏈表的區別,單鏈表是單項的 而雙鏈表是有左右的 題目acwing 827 實現乙個雙鏈表,雙鏈表初始為空,支援5種操作 1 在最左側插入乙個數 2 在最右側插入乙個數 3 將第k個插入的數刪除 4 在第k個插入的數左側插入乙個數 5 在第k...
資料結構 雙鏈表
單鏈表結點中只有乙個只指向後繼的指標,使得單鏈表只能從頭結點開始一次順序的先後遍歷。要訪問某個結點的前驅結點 插入刪除操作時 只能從頭開始遍歷,訪問後繼節點的時間複雜度為o 1 訪問前驅結點的時間複雜度為o n 為了克服單鏈表的上述缺點,引入了雙鏈表,雙鏈表結點中有兩個指標prior 和 next,...