已知两个非降序链表序列S1与S2,设计函数构造出S1与S2的交集新链表S3。
输入格式:
输入分两行,分别在每行给出由若干个正整数构成的非降序序列,用−1表示序列的结尾(−1不属于这个序列)。数字用空格间隔。
输出格式:
在一行中输出两个输入序列的交集序列,数字间用空格分开,结尾不能有多余空格;若新链表为空,输出NULL
。
输入样例:
1 2 5 -1
2 4 5 8 10 -1
输出样例:
2 5
代码(C)
/* 1-7 两个有序链表序列的交集 */
/* Asunne */
/* 2022/12/18 */
#include <stdio.h>
#include <stdlib.h>
/* 链表结点的定义 */
typedef struct Node *PtrToNode;
struct Node
{
int data;
PtrToNode Next;
};
typedef PtrToNode List;
/* 创建链表 */
List CreateList()
{
List L = (List)malloc(sizeof(struct Node));
L->Next = NULL;
List q;
List p = L;
int data;
scanf("%d", &data);
while (data != -1)
{
q = (List)malloc(sizeof(struct Node));
q->data = data;
p->Next = q;
p = p->Next;
scanf("%d", &data);
}
p->Next = NULL;
return L;
}
/* 求交集(实在想不到名字了,就叫在一起吧) */
List getTogether(List L1, List L2)
{
List p = L1->Next;
List q = L2->Next;
List L = (List)malloc(sizeof(struct Node));
List r = L;
while (p && q)
{
if (p->data > q->data)
q = q->Next;
else if (p->data < q->data)
p = p->Next;
else
{
r->Next = q;
q = q->Next;
p = p->Next;
r = r->Next;
}
}
r->Next = NULL;
return L;
}
/* 输出链表(带有头结点的输出) */
void printList(List L)
{
List p = L->Next; // 先让L指向第一个有数据的单元
while (p)
{
if (p->Next == NULL)
printf("%d ", p->data);
else
printf("%d ", p->data);
p = p->Next;
}
}
int main()
{
List L1 = CreateList();
List L2 = CreateList();
List L3 = getTogether(L1, L2);
printList(L3);
return 0;
}