Programa C++ para eliminar duplicados de una lista enlazada sin clasificar

Escriba una función removeDuplicates() que tome una lista y elimine cualquier Node duplicado de la lista. La lista no está ordenada. 
Por ejemplo, si la lista vinculada es 12->11->12->21->41->43->21, removeDuplicates() debería convertir la lista a 12->11->21->41->43.

MÉTODO 1 (Uso de dos bucles): 
Esta es la forma sencilla en la que se utilizan dos bucles. El bucle externo se usa para seleccionar los elementos uno por uno y el bucle interno compara el elemento seleccionado con el resto de los elementos. 
Gracias a Gaurav Saxena por su ayuda al escribir este código.

C++

// C++ Program to remove duplicates in an 
// unsorted linked list 
#include <bits/stdc++.h>
using namespace std;
  
// A linked list node 
struct Node 
{
    int data;
    struct Node* next;
};
  
// Utility function to create a 
// new Node
struct Node* newNode(int data)
{
    Node* temp = new Node;
    temp->data = data;
    temp->next = NULL;
    return temp;
}
  
/* Function to remove duplicates from a
   unsorted linked list */
void removeDuplicates(struct Node* start)
{
    struct Node *ptr1, *ptr2, *dup;
    ptr1 = start;
  
    // Pick elements one by one 
    while (ptr1 != NULL &&
           ptr1->next != NULL) 
    {
        ptr2 = ptr1;
  
        /* Compare the picked element with rest
           of the elements */
        while (ptr2->next != NULL) 
        {
            /* If duplicate then delete it */
            if (ptr1->data == ptr2->next->data) 
            {
                // Sequence of steps is important here 
                dup = ptr2->next;
                ptr2->next = ptr2->next->next;
                delete (dup);
            }
            else 
                ptr2 = ptr2->next;
        }
        ptr1 = ptr1->next;
    }
}
  
// Function to print nodes in a given 
// linked list 
void printList(struct Node* node)
{
    while (node != NULL) 
    {
        printf("%d ", node->data);
        node = node->next;
    }
}
  
// Driver code
int main()
{
    // The constructed linked list is:
    // 10->12->11->11->12->11->10
    struct Node* start = newNode(10);
    start->next = newNode(12);
    start->next->next = newNode(11);
    start->next->next->next = newNode(11);
    start->next->next->next->next = newNode(12);
    start->next->next->next->next->next = newNode(11);
    start->next->next->next->next->next->next = newNode(10);
  
    printf("Linked list before removing duplicates ");
    printList(start);
    removeDuplicates(start);
  
    printf("Linked list after removing duplicates ");
    printList(start);
    return 0;
}

Producción: 

Linked list before removing duplicates:
10 12 11 11 12 11 10 
Linked list after removing duplicates:
10 12 11

Complejidad del tiempo: O(n^2)

MÉTODO 2 (Uso de clasificación): 
En general, Merge Sort es el algoritmo de clasificación más adecuado para clasificar listas vinculadas de manera eficiente. 
1) Ordenar los elementos usando Merge Sort. Pronto escribiremos una publicación sobre cómo ordenar una lista enlazada. O(nLogn) 
2) Eliminar duplicados en tiempo lineal utilizando el algoritmo para eliminar duplicados en Lista enlazada ordenada. O(n) 
Tenga en cuenta que este método no conserva el orden original de los elementos.
Complejidad de tiempo: O (nLogn)

MÉTODO 3 (Usar Hashing): 
Recorremos la lista de enlaces de principio a fin. Para cada elemento recién encontrado, verificamos si está en la tabla hash: si es así, lo eliminamos; de lo contrario, lo ponemos en la tabla hash.

C++

// C++ Program to remove duplicates in an 
// unsorted linked list
#include<bits/stdc++.h>
using namespace std;
  
// A linked list node 
struct Node
{
    int data;
    struct Node *next;
};
  
// Utility function to create a 
// new Node
struct Node *newNode(int data)
{
   Node *temp = new Node;
   temp->data = data;
   temp->next = NULL;
   return temp;
}
  
/* Function to remove duplicates from a
   unsorted linked list */
void removeDuplicates(struct Node *start)
{
    // Hash to store seen values
    unordered_set<int> seen;
  
    // Pick elements one by one 
    struct Node *curr = start;
    struct Node *prev = NULL;
    while (curr != NULL)
    {
        // If current value is seen before
        if (seen.find(curr->data) != seen.end())
        {
           prev->next = curr->next;
           delete (curr);
        }
        else
        {
           seen.insert(curr->data);
           prev = curr;
        }
        curr = prev->next;
    }
}
  
// Function to print nodes in a given 
// linked list 
void printList(struct Node *node)
{
    while (node != NULL)
    {
        printf("%d ", node->data);
        node = node->next;
    }
}
  
// Driver code
int main()
{
    /* The constructed linked list is:
       10->12->11->11->12->11->10*/
    struct Node *start = newNode(10);
    start->next = newNode(12);
    start->next->next = newNode(11);
    start->next->next->next = newNode(11);
    start->next->next->next->next = newNode(12);
    start->next->next->next->next->next = newNode(11);
    start->next->next->next->next->next->next = newNode(10);
  
    printf("Linked list before removing duplicates : ");
    printList(start);
    removeDuplicates(start);
  
    printf("Linked list after removing duplicates : ");
    printList(start);
    return 0;
}

Producción: 

Linked list before removing duplicates:
10 12 11 11 12 11 10 
Linked list after removing duplicates:
10 12 11

Gracias a bearwang por sugerir este método.
Complejidad de tiempo: O (n) en promedio (suponiendo que el tiempo de acceso a la tabla hash es O (1) en promedio).

¡ Consulte el artículo completo sobre Eliminar duplicados de una lista enlazada sin ordenar para obtener más detalles!

Publicación traducida automáticamente

Artículo escrito por GeeksforGeeks-1 y traducido por Barcelona Geeks. The original can be accessed here. Licence: CCBY-SA

Deja una respuesta

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *