ALG4

ALG4



114 Rozdział 5. Struktury danych

stan—ZAKOŃCZ; else {

przcd=po;

po=po->nastepny;

I

Różnica pomiędzy tymi dwiema pętlami while tkwi wyłącznie w warunku instrukcji if. else. Idea naszego rozwiązania jest zatem następująca: napiszmy uniwersalną funkcję, która posłuży do odszukiwania wskaźników przed i po w celu ich późniejszego użycia do dokładania elementów do listy, jak również do ich usuwania. Funkcja ta powinna nam zwrócić oba wskaźniki - posłużymy się do tego celu strukturą LPTRINFO (patrz strona 112), umawiając się, że pole głowa będzie odpowiadało wskaźnikowi przed, a pole ogon - wskaźnikowi po.

Łatwo jest zauważyć, że operacje poszukiwania, wstawiania etc. rozpoczynamy od listy wskaźników, z której zdobędziemy adres rekordu danych (adres ten jest/zostanie zapamiętany w polu adres struktury LPTR. która stanowi element składowy listy wskaźników - patrz rysunek 5 - 9). Dopiero po zmodyfikowaniu wszystkich list wskaźników (a może ich być tyle, ile przyjmiemy kryteriów sortowania) należy zmodyfikować listę danych. Pracy jest - jak widać - mnóstwo, ale jest to cena za wygodę późniejszego użytkowania takiej listy! Pocieszeniem niech będzie fakt, że po jednokrotnym napisaniu odpowiedniego zestawu funkcji bazowych będziemy mogli z nich później wielokrotnie korzystać bez konieczności przypominania sobie, jak one to robią... Przejdźmy już do opisu realizacji funkcji odszukaj_wsk. która zajmie się poszukiwaniem wskaźników przed i po, zwracając je w strukturze LPTR INFO:

LISTA::LPTR_INFO* LISTA::odszukaj_wsk (LISTA::LPTR_INFO *inf,

SLSMSNT *q,

int(‘decyzja)(ELEMENT *ql,ELEMENT *q2>)

<

LPTR INFO *res=now LPTR_INFO;

res->glowa=res->ogon=NULL;

if (inf->glowa==NUT,T.)

return(res); // lisLa pusta!

else

{

LPTR *przed,*pos;

przcd-NULL;

pos=inf->giowa;

onum (SZUKAJ,ZAKOŃCZ) stan=SZUKAJ; while ((stan==S2UKAJ) ś& (pos!=NULL)) if (decyzja(pos-sadres,q)) stan=ZAKONCZ;

II znaleźliśmy miejsce w którym element else    // istnieje (albo ma być wstawiony)

(    // przemieszczamy sie w poszukiwaniach

przed-pos;

pos=pos->nastepny;


Wyszukiwarka

Podobne podstrony:
ALG 4 94 Rozdział 5. Struktury danych5.1. Listy jednokierunkowe Lista jednokierunkowa jest oszczędną
ALG4 104 Rozdział 5, Struktury danych dla danego obiektu wykonanie na sobie operacji „dekrementacji
ALG4 124 Rozdział 5. Struktury danych Co jednak z dołączaniem elementów do listy? Poniżej są omówio
ALG4 144 Rozdział 5. Struktury danych studia dotyczące drzew można znaleźć w zasadzie w większości
ALG4 154 Rozdział 5. Struktury danych weźmy pod uwagę następującą grupę słów: KROKUS, KROSNO, KRAWI
ALG 6 96 Rozdział 5. Struktury danych Rys. 5 - 3. FCOOh FCI4h FFEEh Przykład listy jedno-kierunk
ALG 8 98 Rozdział 5. Struktury danych W następnych paragrafach zostaną przedstawione wszystkie metod
ALG2 102___Rozdział 5. Struktury danych I ELEMENT *q=inf.głowa; if (pusta()) cout << "(l
ALG8 108__Rozdział 5. Struktury danych5.1.3.Listy jednokierunkowe - teoria i rzeczywistość Oprócz p
ALG0 110 Rozdział 5. Struktury danych Rysunek 5-9 zawiera już kilka nowości w porównaniu z tym, co
ALG2 112 Rozdział 5. Struktury danych 112 Rozdział 5. Struktury danych //rekord informacyjny listy
ALG6 116 Rozdział 5. Struktury danych Iisla2.li int alfabetycznie(ELEMENT *q],ELEMENT *q2) { II czy
ALG8 118 Rozdział 5. Struktury danych if(pŁzed==NULL) // wstawiamy na początek listy ( inf_ptr[nr].
ALG0 120 Rozdział 5. Struktury danych i if (pos!=q) rsturn(O);    II element nie
Alg0 120 Rozdział 5. Struktury danych i if (pos!=q) rsturn(O);    II element nie
ALG2 122 Rozdział 5. Struktury danych Czerniak zarabia 3000zl Wynik usunięcia rekordu pracownika za
ALG6 126 Rozdział 5. Struktury danych Rys. 5 - 12. Metoda„ tablic równoległych " (2) DANE L2
ALG0 130 Rozdział 5. Struktury danych Symboliczny stos znajdujący się pod każdą z sześciu grup inst
ALG4 134 Rozdział 5. Struktury danyct Jak to zwykle bywa, możliwych implementacji kolejek jest co n

więcej podobnych podstron