C语言数据结构实现链表去重的实例
C语言数据结构实现链表去重的实例
题目及分析
链表去重
时间限制 300ms 内存限制 65536kB 代码长度限制 8000B 判题程序 Standard
给定一个带整数键值的单链表L,本题要求你编写程序,删除那些键值的绝对值有重复的结点。即对任意键值K,只有键值或其绝对值等于K的第一个结点可以被保留。同时,所有被删除的结点必须被保存在另外一个链表中。例如:另L为21→-15→-15→-7→15,则你必须输出去重后的链表21→-15→-7、以及被删除的链表-15→15。
输入格式:
输入第一行包含链表第一个结点的地址、以及结点个数N(<=105的正整数)。结点地址是一个非负的5位整数,NULL指针用-1表示。
随后N行,每行按下列格式给出一个结点的信息:
AddressKeyNext
其中Address是结点的地址,Key是绝对值不超过104的整数,Next是下一个结点的地址。
输出格式:
首先输出去重后的链表,然后输出被删除结点组成的链表。每个结点占一行,按输入的格式输出。
输入样例:
001005 99999-787654 23854-1500000 8765415-1 00000-1599999 001002123854
输出样例:
001002123854 23854-1599999 99999-7-1 00000-1587654 8765415-1
三、代码及结果
//L2-002.链表去重 /* 输入得到的是乱序链表,排个顺序让它成为正常的序列 然后开始输出链表,用集合set来辅助看是不是绝对之已经输出过,如果是,就放在删除链表所在的链 */ #include#include #include #include //abs函数 usingnamespacestd; stringfirstAdd; intn; structnode{ stringadd; intvalue; stringnext; intsortNul; intvis; }a[10005],b[10005],d[10005]; booloperator<(constnode&p,constnode&p1){ returnp.sortNul >firstAdd>>n; for(inti=1;i<=n;i++){ cin>>a[i].add>>a[i].value>>a[i].next; a[i].sortNul=0; a[i].vis=0; } } voidprintData(){ for(inti=1;i<=n;i++){ cout<set1; intb1=0,d1=0; voidfindAns(){ for(inti=1;i<=n;i++){ if(!set1.count(abs(a[i].value))){ set1.insert(abs(a[i].value)); b[++b1]=a[i]; } else{ d[++d1]=a[i]; } } //修正链表 for(inti=1;i 以上就是对链表去重的讲解,本地对于数据结构的文章还很多,希望大家能搜索查看,感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!