PTA L2 002 鍊錶去重

2021-09-14 02:20:52 字數 1514 閱讀 1043

給定乙個帶整數鍵值的鍊錶 l,你需要把其中絕對值重複的鍵值結點刪掉。即對每個鍵值 k,只有第乙個絕對值等於 k 的結點被保留。同時,所有被刪除的結點須被儲存在另乙個鍊錶上。例如給定 l 為 21→-15→-15→-7→15,你需要輸出去重後的鍊錶 21→-15→-7,還有被刪除的鍊錶 -15→15。

輸入在第一行給出 l 的第乙個結點的位址和乙個正整數 n(≤10​5​​,為結點總數)。乙個結點的位址是非負的 5 位整數,空位址 null 用 −1 來表示。

隨後 n 行,每行按以下格式描述乙個結點:

首先輸出去重後的鍊錶,然後輸出被刪除的鍊錶。每個結點佔一行,按輸入的格式輸出。

00100 5

99999 -7 87654

23854 -15 00000

87654 15 -1

00000 -15 99999

00100 21 23854

00100 21 23854

23854 -15 99999

99999 -7 -1

00000 -15 87654

87654 15 -1

第一遍寫的時候我用的鍊錶、、可夠麻煩的、還出了點毛病

後來用結構體陣列模擬鍊錶,開兩個分別儲存結果和需要刪除的,輸出的時候最後一位指向的是 -1;

#includeusing namespace std;

typedef long long ll;

#define readc(x) scanf("%c",&x)

#define read(x) scanf("%d",&x)

#define read2(x,y) scanf("%d%d",&x,&y)

#define read3(x,y,z) scanf("%d%d%d",&x,&y,&z)

#define print(x) printf("%d\n",x)

#define mst(a,b) memset(a,b,sizeof(a))

#define pb push_back

#define mp make_pair

const int inf =0x3f3f3f3f;

const int mod = 1e9+7;

const int maxn = 505 ;

const int maxn = 1e5 + 10;

struct nodelst[maxn];

struct node2ans[maxn],del[maxn];

int n;

int p ;

int cnt[maxn];

int main()

int i = 0, j = 0;

while(p != -1)

else

p = lst[p].next;

} int k;

for(k = 0; k < i; k++)

for(k = 0; k < j; k++)

}

PTA L2 002 鍊錶去重

給定乙個帶整數鍵值的鍊錶 l,你需要把其中絕對值重複的鍵值結點刪掉。即對每個鍵值 k,只有第乙個絕對值等於 k 的結點被保留。同時,所有被刪除的結點須被儲存在另乙個鍊錶上。例如給定 l 為 21 15 15 7 15,你需要輸出去重後的鍊錶 21 15 7,還有被刪除的鍊錶 15 15。輸入在第一行...

PTA L2 002 鍊錶去重

給定乙個帶整數鍵值的鍊錶 l,你需要把其中絕對值重複的鍵值結點刪掉。即對每個鍵值 k,只有第乙個絕對值等於 k 的結點被保留。同時,所有被刪除的結點須被儲存在另乙個鍊錶上。例如給定 l 為 21 15 15 7 15,你需要輸出去重後的鍊錶 21 15 7,還有被刪除的鍊錶 15 15。輸入在第一行...

L2 002 鍊錶去重

給定乙個帶整數鍵值的單鏈表l,本題要求你編寫程式,刪除那些鍵值的絕對值有重複的結點。即對任意鍵值k,只有鍵值或其絕對值等於k的第乙個結點可以被保留。同時,所有被刪除的結點必須被儲存在另外乙個鍊錶中。例如 另l為21 15 15 7 15,則你必須輸出去重後的鍊錶21 15 7 以及被刪除的鍊錶 15...