L2-002 鏈表去重(25 分)

L2-002 鏈表去重(25 分)
給定一個帶整數鍵值的單鏈表L,本題要求你編寫程序,刪除那些鍵值的絕對值有重複的結點。即對任意鍵值K,只有鍵值或其絕對值等於K的第一個結點能夠被保留。同時,全部被刪除的結點必須被保存在另一個鏈表中。例如:另L爲21→-15→-15→-7→15,則你必須輸出去重後的鏈表21→-15→-七、以及被刪除的鏈表-15→15。node

輸入格式:ios

輸入第一行包含鏈表第一個結點的地址、以及結點個數N(<= 10^5^ 的正整數)。結點地址是一個非負的5位整數,NULL指針用-1表示。web

隨後N行,每行按下列格式給出一個結點的信息:svg

Address Key Nextui

其中Address是結點的地址,Key是絕對值不超過10^4^的整數,Next是下一個結點的地址。spa

輸出格式:指針

首先輸出去重後的鏈表,而後輸出被刪除結點組成的鏈表。每一個結點佔一行,按輸入的格式輸出。code

輸入樣例:xml

00100 5
99999 -7 87654
23854 -15 00000
87654 15 -1
00000 -15 99999
00100 21 23854
輸出樣例:string

00100 21 23854
23854 -15 99999
99999 -7 -1
00000 -15 87654
87654 15 -1

題目要求刪除鍵值的絕對值有重複的結點,
而後先輸出刪除後的鏈表,在輸出被刪除的鏈表

#include<iostream>
#include<cstdio>
#include<algorithm>
using namespace std;
const int maxn = 1e5;
struct Node{
    int address;
    int key;
    int next;
    int num;
}node[maxn];
bool vis[maxn];
bool cmp(Node a,Node b){
    return a.num<b.num;
}
int main()
{
    int head,n,a;
    scanf("%d%d",&head,&n);
    int k1=0,k2=0;
    for(int i=0;i<maxn;i++){
        node[i].num=2*maxn;
    }
    for(int i=0;i<n;i++){
        scanf("%d",&a);
        scanf("%d%d",&node[a].key,&node[a].next);
        node[a].address=a;
             }
    for(int i=head;i!=-1;i=node[i].next){
        if(!vis[abs(node[i].key)]){
            vis[abs(node[i].key)]=true;
            node[i].num=k1;
            k1++;
        }else{
            node[i].num=maxn+k2;
            k2++;
        }
    }
    sort(node,node+maxn,cmp);
    int k=k1+k2;
    for(int i=0;i<k;i++){
        if(i!=k1-1&&i!=k-1){
            printf("%05d %d %05d\n",node[i].address,node[i].key,node[i+1].address);
        }else{
            printf("%05d %d -1\n",node[i].address,node[i].key);
        }
    }
    return 0;
}