Реализация списков на основе динамических структур.


Рассмотрим программу, реализующую односвязный линейный список. В качестве данных, сохраняемых в элементах списка, будем использовать некоторое имя и деньги.

Заголовочный файл list1.h выглядит так:

#ifndef LISTS1_

#define LISTS1_

 

#include <string.h>

#include <stdio.h>

#include <stdlib.h>

#include <malloc.h>

#include <conio.h>

 

//////////////////////////////////////////////////////

// Данные (информация), хранящиеся в элементе списка

//////////////////////////////////////////////////////

typedef struct

{

char name[20];

double money;

} ELEMENT, *pELEMENT;

//////////////////////////////////////////////////////

// Элемент списка

//////////////////////////////////////////////////////

typedef struct

{

pELEMENT inf; // Указатель на информацию

void *next; // Указатель на следующий блок

} LIST1, *pLIST1;

 

//////////////////////////////////////////////////////

// Добавить в конец списка новый элемент

pLIST1 AddToLists1(pELEMENT pInf);

// Добавить в список после заданного элемента

pLIST1 AddToLists1Elem(char* pName, pELEMENT pInfNew);

// Удалить из списка заданный элемент (первый, если pName==NULL)

pLIST1 DelFromLists1(char* pName);

// Найти в списке заданный элемент

pLIST1 FindInLists1(char* pName);

 

// Вывести содержание списка

void PrintLists1(void);

//////////////////////////////////////////////////////

 

extern pLIST1 pHead;

 

#endif //LISTS1_

Текст программы, реализующей описанный интерфейс, может выглядеть так: (lists1.cpp):

#include "lists1.h"

//////////////////////////////////////////////////////////////////////

// Добавить в конец списка новый элемент

//////////////////////////////////////////////////////////////////////

pLIST1 AddToLists1(pELEMENT pInf)

{

pLIST1 pNew,pCur;

pELEMENT pInfNew;

pNew = (pLIST1)malloc(sizeof(LIST1));

pInfNew = (pELEMENT)malloc(sizeof(ELEMENT));

 

strcpy(pInfNew->name, pInf->name);

pInfNew->money = pInf->money;

 

pNew->inf = pInfNew;

pNew->next = NULL;

if (pHead==NULL) pHead = pNew;

else

{

pCur = pHead;

while (pCur->next!=NULL) pCur = (pLIST1)pCur->next;

pCur->next = pNew;

}

return pNew;

}

////////////////////////////////////////////////////////////////

Добавить в список после заданного элемента или в конец,если такого нет

////////////////////////////////////////////////////////////////

pLIST1 AddToLists1Elem(char* pName, pELEMENT pIN)

{

pLIST1 pNew,pCur;

pELEMENT pInfNew, pW;

 

pNew = (pLIST1)malloc(sizeof(LIST1));

pInfNew = (pELEMENT)malloc(sizeof(ELEMENT));

 

strcpy(pInfNew->name, pIN->name);

pInfNew->money = pIN->money;

 

pNew->inf = pInfNew;

pNew->next = NULL;

if (pHead==NULL) pHead = pNew;

else

{

pCur = pHead;

while (pCur->next!=NULL)

{

pW = pCur->inf;

if (!strcmp(pW->name, pName))

{

pNew->next = pCur->next; break;

}

pCur = (pLIST1)pCur->next;

}

pCur->next = pNew;

}

return pNew;

}

 

////////////////////////////////////////////////////////////////

// Удалить из списка заданный элемент (первый, если pName==NULL)

////////////////////////////////////////////////////////////////

pLIST1 DelFromLists1(char* pName)

{

pLIST1 pCur, pPrev=NULL;

pELEMENT pW;

 

if (pHead==NULL) return NULL;

pCur = pHead;

if (pName==NULL) // Удаление из головы списка

{

pPrev = (pLIST1)pCur->next;

free(pCur->inf); free(pCur);

pHead = pPrev;

return pPrev;

}

do

{

pW = pCur->inf;

if (!strcmp(pW->name, pName))

{

free(pW);

if (pPrev==NULL)

{

free(pHead);

pHead=NULL;

}

else

{

pPrev->next = pCur->next;

free(pCur);

}

return pPrev;

}

else

pPrev = pCur;

pCur = (pLIST1)pCur->next;

} while (pCur->next!=NULL);

 

pW = pCur->inf;

if (!strcmp(pW->name, pName))

{

free(pW);

pPrev->next=NULL;

free(pCur);

return pPrev;

}

else

return NULL;

}

 

////////////////////////////////////////////////////////////////

// Найти в списке заданный элемент

////////////////////////////////////////////////////////////////

pLIST1 FindInLists1(char* pName)

{

pLIST1 pCur;

pELEMENT pW;

 

if (pHead==NULL) return NULL;

pCur = pHead;

do

{

pW = pCur->inf;

if (!strcmp(pW->name, pName)) return pCur;

pCur = (pLIST1)pCur->next;

} while (pCur->next!=NULL);

 

pW = pCur->inf;

if (!strcmp(pW->name, pName)) return pCur;

return NULL;

}

 

////////////////////////////////////////////////////////////////

// Вывести содержание списка

////////////////////////////////////////////////////////////////

void PrintLists1()

{

pLIST1 pCur;

pELEMENT pW;

if (pHead==NULL) return;

pCur = pHead;

printf("\n---------- Content of the list -----------");

while (pCur->next!=NULL)

{

pW = pCur->inf;

printf("\n%-20s %.2lf", pW->name, pW->money);

pCur = (pLIST1)pCur->next;

}

pW = pCur->inf;

printf("\n%-20s %.2lf", pW->name, pW->money);

printf("\n------------------------------------------");

}

 



Дата добавления: 2022-02-05; просмотров: 372;


Поиск по сайту:

Воспользовавшись поиском можно найти нужную информацию на сайте.

Поделитесь с друзьями:

Считаете данную информацию полезной, тогда расскажите друзьям в соц. сетях.
Poznayka.org - Познайка.Орг - 2016-2024 год. Материал предоставляется для ознакомительных и учебных целей.
Генерация страницы за: 0.015 сек.