120 likes | 225 Views
SYSTÉMOVÁ TŘÍDA SIMSET. Třída SIMSET je druhou standardní systémovou třídou, která obsahuje prostředky pro práci se spojovými seznamy. KRUHOVÉ SPOJOVÉ SEZNAMY Spojový seznam – velmi často používaná datová struktura Práce se spojovými seznamy
E N D
SYSTÉMOVÁ TŘÍDA SIMSET Třída SIMSET je druhou standardní systémovou třídou, která obsahuje prostředky pro práci se spojovými seznamy. KRUHOVÉ SPOJOVÉ SEZNAMY Spojový seznam – velmi často používaná datová struktura Práce se spojovými seznamy Způsob práce se spojovým seznamem a konkrétní složitost obslužných algoritmů jsou závislé na použité organizaci seznamu.
SIMULACE DISKRÉTNÍCH SYSTÉMŮ Jednosměrný spojový seznam Jedná se o nejjednodušší strukturu realizující spojový seznam. Každý prvek odkazuje na svého následníka a je zpřístupněn jednou referenční proměnnou, která odkazuje na první prvek. Zpřístupňující proměnná Obsah položky Odkaz na následující prvek seznamu
SIMULACE DISKRÉTNÍCH SYSTÉMŮ Dvousměrný spojový seznam Každý prvek odkazuje jak na svého předchůdce, tak na svého následníka a zpřístupnění je možné na jednom či druhém či obou koncích. Singulární případy při zařazování či ubírání na některém z konců seznamu. Zpřístupňují proměnné Odkaz na předcházející prvek seznamu Odkaz na následující prvek seznamu Obsah položky
SIMULACE DISKRÉTNÍCH SYSTÉMŮ Kruhový spojový seznam Singulární případy lze zamezit kruhovou organizací seznamu,tj. první prvek prohlásíme definitoricky následníkem posledního prvku a poslední prvek předchůdcem prvního. Ke zpřístupnění „ obou konců“ kruhového seznamu stačí jediná referenční proměnná. Zpřístupňující proměnná
SIMULACE DISKRÉTNÍCH SYSTÉMŮ Reprezentace prázdného seznamu Zbývající singularita – práce s „ prázdným seznamem“, tj. zařazování prvního a vyjímání poslední prvku seznamu. Odstranění – přidání speciálního prvku, který nebudeme počítat mezi prvky seznamu a který nebudeme nikdy ze seznamu vypouštět Speciální prvek
SIMULACE DISKRÉTNÍCH SYSTÉMŮ Prázdný seznam v tomto pojetí bude reprezentován seznamem (stále kruhovým) obsahující pouze zmíněný speciální prvek.
SIMULACE DISKRÉTNÍCH SYSTÉMŮ • Filozofie třídy SIMSET • Popsané pojetí cyklických kruhových seznamů obsahujících speciální prvek, který nebudeme počítat mezi vlastní členy seznamu budeme nazývat hlavou seznamu. • Základní datová struktura – stejná jak pro prvky seznamu tak pro jeho hlavu, tj. odpovídající datový prototyp musí obsahovat dvě složky pro referenční odkazy na následníka a předchůdce v seznamu. • Prefixační systém jazyka PC-SIMULA umožňuje, aby datové prototypy vlastních prvků seznamu a jeho hlavy byly kvalifikačně odlišné, tj. ke třídě základní datové struktury vytvoříme dvě podtřídy: • prototyp hlav seznamů • prototyp vlastních prvků seznamů
SIMULACE DISKRÉTNÍCH SYSTÉMŮ • V třídě SIMSET je takové kvalifikační odlišení realizováno. • základní datový prototyp – třída linkage • podtřída prototyp hlav seznamů – třída head • podtřída prototyp vlastních prvků seznamu – třída link linkage head link
SIMULACE DISKRÉTNÍCH SYSTÉMŮ Deklarace systémové třídy SIMSET : class Simset; begin classlinkage begin ref (linkage) SUC, PRED; …. end; linkageclasshead; …; linkageclasslink; …; end ;
SIMULACE DISKRÉTNÍCH SYSTÉMŮ Deklarace třídy linkage: - základní prototyp struktury řazené do kruhového dvousměrného seznamu classlinkage; begin ref(linkage) SUC, PRED; ref(linkage) procedure suc; suc:-if SUCin link thenSUCelse none; ref(linkage) procedure pred; pred:-ifPREDin link thenPREDelse none; ref(linkage) procedure prev; prev:- PRED; end ; - identifikátory složené z velkých písmen označují uživateli nedostupné veličiny
SIMULACE DISKRÉTNÍCH SYSTÉMŮ • Třída head: • prototyp hlavy seznamu, nerozšiřuje třídu linkage • z uživatelského hlediska je celý seznam reprezentován (zpřístupňován) právě hlavou. • Procedury: • procedurefirst – funkční hodnotou je odkaz na první položku v seznamu, pro prázný seznam nabývá hodnoty none • procedurelast – odkazuje na poslední položku seznamu, pro prázný seznam nabývá hodnoty none • procedure empty – nabývá hodnoty true při prázdném seznamu • procedurecardinal – funkční hodnotou je celé číslo udávající počet položek seznamu • procedureclear – odstraňuje všechny položky ze seznamu
SIMULACE DISKRÉTNÍCH SYSTÉMŮ • Třída link: • Prototyp exemplářů chápaných jako vlastní prvky spojového seznamu. Obsahuje pouze deklarace lokálních procedur – nerozšiřuje třídu linkage • pouze kvalifikační odlišení vlastních prvků spojového seznamu od jeho hlavy – rozdíl jen v obslužných procedurách • Procedury: • procedureout – odstraňuje položku ze seznamu • procedureinto(S) – zařazuje položku na konec seznamu • procedure follow(X) – zařazuje položku do seznamu za objekt odkazovaný parametrem X • procedureprecede(X) – zařazuje položku do seznamu před objekt odkazovaný parametrem X