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.