Table of Contents

7. úkol - Simple car database

Vaším úkolem je vytvořit jednoduchou databázi aut. K implementaci použijte spojový seznam. Databáze aut má metodu na její vytvoření z předem definovaného pole, metodu na vložení automobilu do db, metodu na úpravu názvu již vloženého automobilu, metodu na úpravu značky již vloženého automobilu a metodu na změny stavu již vloženého automobilu. Pro zjednodušení není umožňěno měnit cenu automobilu. Dále databáze disponuje metodou, která umí vypočítat celkovou hodnotu aut v showroomu. Databáze má také metodu, která vrátí hlavičku spojového seznamu, spojový seznam samotný a metodu, která databázi vymaže. Více informací o metodách níže.

Pro databázi platí následující omezení: V DB nejsou žádná ID vícekrát. V DB jsou záznamy vždy seřazeny podle ceny od nejnižší po nejvyšší a to v pořadí v jakém byly vkládány.

Pro spojový seznam platí následující omezení: Každý uzel vidí na svého předka a na svého následníka. V každém uzlu jsou uložena všechna data o konkrétním automobilu.

K implementaci použijte tuto šablonu: showroom.py
K vyhodnocení používáme python verze 3.

Datová struktura

Vytvořte třídu showroom.py, která bude obsahovat níže specifikované třídy a metody.

CAR

Třída Car má následující proměnné: identification, name, brand, price, active:

Nebo-li třída Car jsou data, která jsou uložena v každé Node.

Node

Třída Node reprezentuje uzel ve spojovém seznamu. V našem případě má následující proměnné: nextNode, prevNode, data. Níže je popis jednotlivých proměnných:

V případě posledního uzlu ve spojovém seznamu je hodnota nextNode = None, v případě prvního uzlu ve spojovém seznamu je hodnota prevNode = None, v případě jednoprvkového seznamu je v proměných hlavy spojového seznamu hodnota nextNode=prevNode = None. V případě prázdného spojového seznamu je hodnota hlavy None

LinkedList

Třída LinkedList reprezentuje spojový seznam a drží si hlavičku spojového seznamu, pomocí které lze projít celý spojový seznam. Nebo-li prohledat DB. Tato třída může obsahovat i metody, které pracují se spojovým seznamem. Spojovy seznam tedy implementujete jako tridu s vlastnimi promenymi, ale metody pro obsluhu DB muzete rovnou implementovat jako proste funkce v souboru showroom.py

Metody

Níže je seznam metod, které musí databáze poskytovat (očekáváme je v souboru showroom.py), včetně jejich definice a popisu.

V případě, že se metodám updateName, updateBrand, activateCar, deactivateCar nepodaří najít vůz podle daného identifikátoru, metody vrátí return None.

Nutné podmínky

Bodování

Za úlohu je možné získat 7 bodů. 4 body jsou za správné vytvoření spojového seznamu metodou init, za správnou implementaci metody clean a za správné implementace metod, které vrací spojový seznam a jeho hlavičku. Jedná se tedy o tyto metody: getDatabase getDatabaseHead, clean, init. Zbývající 3 body jsou za správnou implementaci ostatních metod nad spojovým seznamem.

Termín odevzdání

Úterní cvičení: 21.11.2017

Páteční cvičení: 1.12.2017

Vždy před začátkem vašeho cvičení.

Aby jste nemuseli na cvičení je nutné odevzdat tento úkol za plný počet bodů. Pro úterní cvičení do 14.11.2017 a pro páteční cvičení do 24.11.2017. Vždy před začátkem vašeho cvičení