链表的交集

Intersection of Linked List

我编写了一个程序来查找两个链表的交集(公共元素),但它无法正常工作。我认为 intersect() 函数中的 while 循环存在一些问题。如果有人能向我解释错误,我将不胜感激。

#include<stdio.h>
#include<conio.h>
#include<stdlib.h>
struct node{
    int data;
    struct node *next;
}; struct node *nw, *head, *tail, *temp;

struct node1{
    int data1;
    struct node1 *next1;
}; struct node1 *nw1, *head1, *tail1, *temp1;

struct node2{
    int data2;
    struct node2 *next2;
}; struct node2 *nw2, *head2, *tail2, *temp2, *t;

void intersect(){
    printf("\nINTERSECTION OF LINKED LIST \n");
    temp=head;
    temp1=head1;
    while(temp->next!=NULL && temp1->next1!=NULL)
    {
        temp->next=head;
        while(temp->data != temp1->data1 && temp->next!=NULL)
        {
                temp=temp->next;  
/* PROBLEM is with this loop it doesnt increment and hence become infinte. */
    }

        if(temp->data == temp1->data1)
        {
            printf("Common Element : %d\t", temp1->data1);
        }
    }
}
int main(){
    int n,i,item,item1;

    printf("Enter the number of nodes of 1st  Linked List");
    scanf("%d", &n);
    nw=(struct node *)malloc(sizeof(struct node));
    nw->data=NULL;
    nw->next=NULL;
    head=nw;
    tail=nw;
    for(i=0;i<n;i++){
        printf("Enter the item ");
        scanf("%d", &item);
        if(head->data==NULL)
            head->data=item;
        else{
            nw=(struct node *)malloc(sizeof(struct node));
            nw->data=item;
            nw->next=NULL;
            tail->next=nw;
            tail=nw;
        }
    }

    printf("Enter the number of nodes for second LL");
    scanf("%d", &n);
    nw1=(struct node1 *)malloc(sizeof(struct node1));
    nw1->data1=NULL;
    nw1->next1=NULL;
    head1=nw1;
    tail1=nw1;
    for(i=0;i<n;i++){
        printf("Enter the item ");
        scanf("%d", &item1);
        if(head1->data1==NULL)
            head1->data1=item1;
        else{
            nw1=(struct node1 *)malloc(sizeof(struct node1));
            nw1->data1=item1;
            nw1->next1=NULL;
            tail1->next1=nw1;
            tail1=nw1;
        }
    }
        temp=head;
        while(temp!=NULL){
            printf("%d    ", temp->data);
            temp=temp->next;
        }
        printf("\n\n\n\n\n");
        temp1=head1;
        while(temp1!=NULL){
            printf("%d    ", temp1->data1);
            temp1=temp1->next1;
        }

        intersect();
        getch();
}

您需要一个嵌套的 for/while 循环来查找所有常见项目。以下代码中的一些内容应该可以工作。

void intersect(){
   printf("\nINTERSECTION OF LINKED LIST \n");
   temp=head;
   temp1=head1;

   for ( ; temp != NULL; temp = temp->next )
   {
      for ( temp1 = head1; temp1 != NULL; temp1 = temp1->next )
      {
         if(temp->data == temp1->data1)
         {
            printf("Common Element : %d\t", temp1->data1);
         }
      }
   }
}