MFC - Listes liées

UNE linked listest une structure de données linéaire où chaque élément est un objet distinct. Chaque élément (nous l'appellerons un nœud) d'une liste comprend deux éléments - les données et une référence au nœud suivant. Le dernier nœud a une référence à null.

Une liste chaînée est une structure de données constituée d'un groupe de nœuds qui représentent ensemble une séquence. C'est un moyen de stocker des données avec des structures afin que le programmeur puisse créer automatiquement un nouvel emplacement pour stocker les données chaque fois que nécessaire. Certaines de ses principales caractéristiques sont -

  • La liste liée est une séquence de liens contenant des éléments.

  • Chaque lien contient une connexion à un autre lien.

  • Chaque élément de la liste est appelé un nœud.

  • Si la liste contient au moins un nœud, un nouveau nœud est positionné comme dernier élément de la liste.

  • Si la liste n'a qu'un seul nœud, ce nœud représente le premier et le dernier élément.

Il existe deux types de liste de liens -

Liste liée individuellement

Les listes à liaison unique sont un type de structure de données. Dans une liste liée individuellement, chaque nœud de la liste stocke le contenu du nœud et un pointeur ou une référence vers le nœud suivant de la liste.

Liste doublement liée

Une liste doublement liée est une structure de données liée qui se compose d'un ensemble d'enregistrements liés séquentiellement appelés nœuds. Chaque nœud contient deux champs qui font référence au nœud précédent et au nœud suivant dans la séquence de nœuds.

Classe CList

MFC fournit une classe CListqui est une implémentation de liste liée de modèle et fonctionne parfaitement. Les listes CList se comportent comme des listes à double lien. Une variable de type POSITION est une clé pour la liste. Vous pouvez utiliser une variable POSITION comme itérateur pour parcourir une liste séquentiellement et comme signet pour contenir une place.

N ° Sr. Nom et description
1

AddHead

Ajoute un élément (ou tous les éléments d'une autre liste) à la tête de la liste (crée une nouvelle tête).

2

AddTail

Ajoute un élément (ou tous les éléments d'une autre liste) à la fin de la liste (crée une nouvelle queue).

3

Find

Obtient la position d'un élément spécifié par la valeur du pointeur.

4

FindIndex

Obtient la position d'un élément spécifié par un index de base zéro.

5

GetAt

Obtient l'élément à une position donnée.

6

GetCount

Renvoie le nombre d'éléments de cette liste.

sept

GetHead

Renvoie l'élément head de la liste (ne peut pas être vide).

8

GetHeadPosition

Renvoie la position de l'élément head de la liste.

9

GetNext

Obtient l'élément suivant pour l'itération.

dix

GetPrev

Obtient l'élément précédent pour l'itération.

11

GetSize

Renvoie le nombre d'éléments de cette liste.

12

GetTail

Renvoie l'élément de queue de la liste (ne peut pas être vide).

13

GetTailPosition

Renvoie la position de l'élément de queue de la liste.

14

InsertAfter

Insère un nouvel élément après une position donnée.

15

InsertBefore

Insère un nouvel élément avant une position donnée.

16

IsEmpty

Teste la condition de liste vide (aucun élément).

17

RemoveAll

Supprime tous les éléments de cette liste.

18

RemoveAt

Supprime un élément de cette liste, spécifié par position.

19

RemoveHead

Supprime l'élément de la tête de la liste.

20

RemoveTail

Supprime l'élément de la fin de la liste.

21

SetAt

Définit l'élément à une position donnée.

Voici les différentes opérations sur les objets CList -

Créer un objet CList

Pour créer une collection de valeurs ou d'objets CList, vous devez d'abord décider du type de valeurs de la collection. Vous pouvez utiliser l'un des types de données primitifs existants tels que int, CString, double, etc., comme indiqué ci-dessous dans le code suivant.

CList<double, double>m_list;

Ajouter des articles

Pour ajouter un élément, vous pouvez utiliser la fonction CList :: AddTail (). Il ajoute un élément à la fin de la liste. Pour ajouter un élément au début de la liste, vous pouvez utiliser la fonction CList :: AddHead (). Dans le CList OnInitDialog (), l'objet est créé et quatre valeurs sont ajoutées comme indiqué dans le code suivant.

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);

Récupérer des éléments

Une variable de type POSITION est une clé pour la liste. Vous pouvez utiliser une variable POSITION comme itérateur pour parcourir une liste de manière séquentielle.

Step 1 - Pour récupérer l'élément de la liste, nous pouvons utiliser le code suivant qui récupérera toutes les valeurs.

//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 - Voici la fonction CMFCCListDemoDlg :: OnInitDialog () complète.

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 - Lorsque le code ci-dessus est compilé et exécuté, vous verrez la sortie suivante.

Ajouter des éléments au milieu

Pour ajouter un élément au milieu de la liste, vous pouvez utiliser les fonctions CList ::. InsertAfter () et CList ::. InsertBefore (). Il faut deux paramètres - Premièrement, la position (où il peut être ajouté) et Deuxièmement, la valeur.

Step 1 - Insérons un nouvel élément comme indiqué dans le code suivant.

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 - Vous pouvez maintenant voir que nous avons d'abord récupéré la position de la valeur 85.26, puis inséré un élément avant et un élément après cette valeur.

Step 3 - Lorsque le code ci-dessus est compilé et exécuté, vous verrez la sortie suivante.

Mettre à jour la valeur de l'élément

Pour mettre à jour l'élément au milieu du tableau, vous pouvez utiliser la fonction CArray ::. SetAt (). Il faut deux paramètres - Premièrement, la position et Deuxièmement, la valeur.

Mettons à jour les 300,00 à 400 dans la liste comme indiqué dans le code suivant.

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
}

Lorsque le code ci-dessus est compilé et exécuté, vous verrez la sortie suivante. Vous pouvez maintenant voir que la valeur de 300,00 est mise à jour à 400,00.

Supprimer des éléments

Pour supprimer un élément particulier, vous pouvez utiliser la fonction CList :: RemoveAt (). Pour supprimer tous les éléments de la liste, la fonction CList :: RemoveAll () peut être utilisée.

Supprimons l'élément, qui a 95,78 comme valeur.

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
}

Lorsque le code ci-dessus est compilé et exécuté, vous verrez la sortie suivante. Vous pouvez maintenant voir que la valeur de 95,78 ne fait plus partie de la liste.