MFC - Listas vinculadas

UN linked listes una estructura de datos lineal donde cada elemento es un objeto separado. Cada elemento (lo llamaremos nodo) de una lista comprende dos elementos: los datos y una referencia al siguiente nodo. El último nodo tiene una referencia a nulo.

Una lista vinculada es una estructura de datos que consta de un grupo de nodos que juntos representan una secuencia. Es una forma de almacenar datos con estructuras para que el programador pueda crear automáticamente un nuevo lugar para almacenar datos cuando sea necesario. Algunas de sus características más destacadas son:

  • La lista vinculada es una secuencia de vínculos que contiene elementos.

  • Cada enlace contiene una conexión a otro enlace.

  • Cada elemento de la lista se denomina nodo.

  • Si la lista contiene al menos un nodo, se coloca un nuevo nodo como último elemento de la lista.

  • Si la lista tiene solo un nodo, ese nodo representa el primer y el último elemento.

Hay dos tipos de listas de enlaces:

Lista individualmente vinculada

Las listas enlazadas simples son un tipo de estructura de datos. En una lista enlazada individualmente, cada nodo de la lista almacena el contenido del nodo y un puntero o referencia al siguiente nodo de la lista.

Lista doblemente vinculada

Una lista doblemente vinculada es una estructura de datos vinculada que consta de un conjunto de registros vinculados secuencialmente llamados nodos. Cada nodo contiene dos campos que son referencias al nodo anterior y al siguiente en la secuencia de nodos.

Clase CList

MFC proporciona una clase CListque es una implementación de lista enlazada de plantilla y funciona perfectamente. Las listas de CList se comportan como listas doblemente enlazadas. Una variable de tipo POSICIÓN es clave para la lista. Puede utilizar una variable POSITION como iterador para recorrer una lista de forma secuencial y como marcador para mantener un lugar.

No Señor. Nombre y descripción
1

AddHead

Agrega un elemento (o todos los elementos de otra lista) al encabezado de la lista (crea un nuevo encabezado).

2

AddTail

Agrega un elemento (o todos los elementos de otra lista) al final de la lista (crea un nuevo final).

3

Find

Obtiene la posición de un elemento especificado por el valor del puntero.

4

FindIndex

Obtiene la posición de un elemento especificado por un índice de base cero.

5

GetAt

Obtiene el elemento en una posición determinada.

6

GetCount

Devuelve el número de elementos de esta lista.

7

GetHead

Devuelve el elemento principal de la lista (no puede estar vacío).

8

GetHeadPosition

Devuelve la posición del elemento principal de la lista.

9

GetNext

Obtiene el siguiente elemento para iterar.

10

GetPrev

Obtiene el elemento anterior para iterar.

11

GetSize

Devuelve el número de elementos de esta lista.

12

GetTail

Devuelve el elemento final de la lista (no puede estar vacío).

13

GetTailPosition

Devuelve la posición del elemento de cola de la lista.

14

InsertAfter

Inserta un nuevo elemento después de una posición determinada.

15

InsertBefore

Inserta un nuevo elemento antes de una posición determinada.

dieciséis

IsEmpty

Prueba la condición de lista vacía (sin elementos).

17

RemoveAll

Elimina todos los elementos de esta lista.

18

RemoveAt

Elimina un elemento de esta lista, especificado por posición.

19

RemoveHead

Elimina el elemento del encabezado de la lista.

20

RemoveTail

Elimina el elemento de la cola de la lista.

21

SetAt

Establece el elemento en una posición determinada.

A continuación se muestran las diferentes operaciones en los objetos CList:

Crear objeto CList

Para crear una colección de valores u objetos CList, primero debe decidir el tipo de valores de la colección. Puede utilizar uno de los tipos de datos primitivos existentes, como int, CString, double, etc., como se muestra a continuación en el siguiente código.

CList<double, double>m_list;

Agregar elementos

Para agregar un elemento, puede usar la función CList :: AddTail (). Agrega un elemento al final de la lista. Para agregar un elemento al comienzo de la lista, puede usar la función CList :: AddHead (). En la CList OnInitDialog (), se crea el objeto y se agregan cuatro valores como se muestra en el siguiente código.

CList<double, double>m_list;

//Add items to the list
m_list.AddTail(100.75);
m_list.AddTail(85.26);
m_list.AddTail(95.78);
m_list.AddTail(90.1);

Recuperar elementos

Una variable de tipo POSICIÓN es clave para la lista. Puede utilizar una variable POSITION como iterador para recorrer una lista de forma secuencial.

Step 1 - Para recuperar el elemento de la lista, podemos usar el siguiente código que recuperará todos los valores.

//iterate the list
POSITION pos = m_list.GetHeadPosition();
while (pos) { 
   double nData = m_list.GetNext(pos);
   CString strVal;
   strVal.Format(L"%.2f\n", nData);
   m_strText.Append(strVal);
}

Step 2 - Aquí está la función CMFCCListDemoDlg :: OnInitDialog () completa.

BOOL CMFCCListDemoDlg::OnInitDialog() {
   CDialogEx::OnInitDialog();

   // Set the icon for this dialog. The framework does this automatically
   // when the application's main window is not a dialog
   SetIcon(m_hIcon, TRUE);             // Set big icon
   SetIcon(m_hIcon, FALSE);             // Set small icon

   // TODO: Add extra initialization here
   CList<double, double>m_list;

   //Add items to the list
   m_list.AddTail(100.75);
   m_list.AddTail(85.26);
   m_list.AddTail(95.78);
   m_list.AddTail(90.1);

   //iterate the list
   POSITION pos = m_list.GetHeadPosition();
   while (pos) {
      double nData = m_list.GetNext(pos);
      CString strVal;
      strVal.Format(L"%.f\n", nData);
      m_strText.Append(strVal);
   }

   UpdateData(FALSE);
 
   return TRUE; // return TRUE unless you set the focus to a control
}

Step 3 - Cuando se compile y ejecute el código anterior, verá el siguiente resultado.

Agregar elementos en el medio

Para agregar un elemento en el medio de la lista, puede usar las funciones CList ::. InsertAfter () y CList ::. InsertBefore (). Se necesitan dos parámetros: primero, la posición (donde se puede agregar) y segundo, el valor.

Step 1 - Insertemos un nuevo elemento como se muestra en el siguiente código.

BOOL CMFCCListDemoDlg::OnInitDialog() {
   CDialogEx::OnInitDialog();
   
   // Set the icon for this dialog. The framework does this automatically
   // when the application's main window is not a dialog
   SetIcon(m_hIcon, TRUE);             // Set big icon
   SetIcon(m_hIcon, FALSE);          // Set small icon

   // TODO: Add extra initialization here
   CList<double, double>m_list;

   //Add items to the list
   m_list.AddTail(100.75);
   m_list.AddTail(85.26);
   m_list.AddTail(95.78);
   m_list.AddTail(90.1);

   POSITION position = m_list.Find(85.26);
   m_list.InsertBefore(position, 200.0);
   m_list.InsertAfter(position, 300.0);

   //iterate the list
   POSITION pos = m_list.GetHeadPosition();
   while (pos) {
      double nData = m_list.GetNext(pos);
      CString strVal;
      strVal.Format(L"%.2f\n", nData);
      m_strText.Append(strVal);
   }

   UpdateData(FALSE);

   return TRUE; // return TRUE unless you set the focus to a control
}

Step 2 - Ahora puede ver que primero recuperamos la posición del valor 85.26 y luego insertamos un elemento antes y un elemento después de ese valor.

Step 3 - Cuando se compile y ejecute el código anterior, verá el siguiente resultado.

Actualizar el valor del artículo

Para actualizar el elemento en el medio de la matriz, puede usar la función CArray ::. SetAt (). Se necesitan dos parámetros: primero, la posición y segundo, el valor.

Actualicemos 300.00 a 400 en la lista como se muestra en el siguiente código.

BOOL CMFCCListDemoDlg::OnInitDialog() {
   CDialogEx::OnInitDialog();

   // Set the icon for this dialog. The framework does this automatically
   // when the application's main window is not a dialog
   SetIcon(m_hIcon, TRUE);              // Set big icon
   SetIcon(m_hIcon, FALSE);            // Set small icon

   // TODO: Add extra initialization here
   CList<double, double>m_list;

   //Add items to the list
   m_list.AddTail(100.75);
   m_list.AddTail(85.26);
   m_list.AddTail(95.78);
   m_list.AddTail(90.1);

   POSITION position = m_list.Find(85.26);
   m_list.InsertBefore(position, 200.0);
   m_list.InsertAfter(position, 300.0);

   position = m_list.Find(300.00);
   m_list.SetAt(position, 400.00);

   //iterate the list
   POSITION pos = m_list.GetHeadPosition();
   while (pos) {
      double nData = m_list.GetNext(pos);
      CString strVal;
      strVal.Format(L"%.2f\n", nData);
      m_strText.Append(strVal);
   }

   UpdateData(FALSE);

   return TRUE; // return TRUE unless you set the focus to a control
}

Cuando se compile y ejecute el código anterior, verá el siguiente resultado. Ahora puede ver que el valor de 300,00 se actualiza a 400,00.

Eliminar elementos

Para eliminar cualquier elemento en particular, puede usar la función CList :: RemoveAt (). Para eliminar todo el elemento de la lista, se puede usar la función CList :: RemoveAll ().

Eliminemos el elemento, que tiene 95,78 como valor.

BOOL CMFCCListDemoDlg::OnInitDialog() {
   CDialogEx::OnInitDialog();

   // Set the icon for this dialog. The framework does this automatically
   // when the application's main window is not a dialog
   SetIcon(m_hIcon, TRUE);              // Set big icon
   SetIcon(m_hIcon, FALSE);             // Set small icon

   // TODO: Add extra initialization here
   CList<double, double>m_list;

   //Add items to the list
   m_list.AddTail(100.75);
   m_list.AddTail(85.26);
   m_list.AddTail(95.78);
   m_list.AddTail(90.1);

   POSITION position = m_list.Find(85.26);
   m_list.InsertBefore(position, 200.0);
   m_list.InsertAfter(position, 300.0);
   
   position = m_list.Find(300.00);
   m_list.SetAt(position, 400.00);

   position = m_list.Find(95.78);
   m_list.RemoveAt(position);

   //iterate the list
   POSITION pos = m_list.GetHeadPosition();
   while (pos) {
      double nData = m_list.GetNext(pos);
      CString strVal;
      strVal.Format(L"%.2f\n", nData);
      m_strText.Append(strVal);
   }
   UpdateData(FALSE);
   
   return TRUE; // return TRUE unless you set the focus to a control
}

Cuando se compile y ejecute el código anterior, verá el siguiente resultado. Ahora puede ver que el valor de 95,78 ya no forma parte de la lista.