Βασικές Δομές Δεδομένων

Σχετικά έγγραφα
Βασικές οµές εδοµένων

Διδάσκων: Κωνσταντίνος Κώστα Διαφάνειες: Δημήτρης Ζεϊναλιπούρ

Διάλεξη 9: Αφηρημένοι Τύποι Δεδομένων. Διδάσκων: Παναγιώτης Ανδρέου

Διάλεξη 05: Αφηρημένοι Τύποι Δεδομένων

ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι 5. Αφηρημένοι Τύποι Δεδομένων / Στοίβες και Ουρές

Διάλεξη 11: Φροντιστήριο για Στοίβες. Διδάσκων: Παναγιώτης Ανδρέου. ΕΠΛ035 Δομές Δεδομένων και Αλγόριθμοι για Ηλ. Μηχ. Και Μηχ. Υπολ.

Διδάσκων: Κωνσταντίνος Κώστα Διαφάνειες: Δημήτρης Ζεϊναλιπούρ

Διδάσκων: Παναγιώτης Ανδρέου

Στοίβες με Δυναμική Δέσμευση Μνήμης

Ενότητα 2 Στοίβες Ουρές - Λίστες. ΗΥ240 - Παναγιώτα Φατούρου 1

Στοίβες Ουρές - Λίστες

Υλοποίηση Λιστών. Στην ενότητα αυτή θα μελετηθούν τα εξής επιμέρους θέματα:

Ενότητα 2 Στοίβες Ουρές - Λίστες

ΕΛΛΗΝΙΚΗ ΔΗΜΟΚΡΑΤΙΑ ΠΑΝΕΠΙΣΤΗΜΙΟ ΚΡΗΤΗΣ. Δομές δεδομένων. Ενότητα 2η: Στοίβες Ουρές - Λίστες Παναγιώτα Φατούρου Τμήμα Επιστήμης Υπολογιστών

IsEmptyList(L): επιστρέφει true αν L = < >, false

Κατ οίκον Εργασία 2 Σκελετοί Λύσεων

Ενότητα 2 Στοίβες Ουρές - Λίστες

υναµικές οµές εδοµένων

ΠΑΝΕΠΙΣΤΗΜΙΟ ΚΥΠΡΟΥ ΤΜΗΜΑ ΠΛΗΡΟΦΟΡΙΚΗΣ

Δομές Δεδομένων (Data Structures)

Ενότητα 2: Στοίβες Ουρές - Λίστες Ασκήσεις και Λύσεις

Διδάσκων: Κωνσταντίνος Κώστα Διαφάνειες: Δημήτρης Ζεϊναλιπούρ

ΕΝΟΤΗΤΑ 3 ΓΡΑΜΜΙΚΕΣ ΛΙΣΤΕΣ

Οι βασικές λειτουργίες (ή πράξεις) που γίνονται σε μια δομή δεδομένων είναι:

Ενότητα 2: Στοίβες Ουρές - Λίστες Ασκήσεις και Λύσεις

Διάλεξη 10: Δομές Δεδομένων Ι (Στοίβες & Ουρές)

Δηάιεμε 8: Αθεξεκέλνη Τύπνη Δεδνκέλσλ

ιαφάνειες παρουσίασης #11

Διάλεξη 12: Λίστες Υλοποίηση & Εφαρμογές. Διδάσκων: Παναγιώτης Ανδρέου

Διάλεξη 07: Λίστες Ι Υλοποίηση & Εφαρμογές

ΕΛΛΗΝΙΚΗ ΔΗΜΟΚΡΑΤΙΑ ΠΑΝΕΠΙΣΤΗΜΙΟ ΚΡΗΤΗΣ

Διορθώσεις σελ

Διάλεξη 22: Δυαδικά Δέντρα. Διδάσκων: Παναγιώτης Ανδρέου

Δομές Δεδομένων & Αλγόριθμοι

Φροντιστήριο 4 Σκελετοί Λύσεων

Πανεπιστήμιο Πειραιώς Σχολή Τεχνολογιών Πληροφορικής και Επικοινωνιών Τμήμα Ψηφιακών Συστημάτων ομές εδομένων

Πανεπιστήμιο Πειραιώς Σχολή Τεχνολογιών Πληροφορικής και Επικοινωνιών Τμήμα Ψηφιακών Συστημάτων ομές εδομένων

Εργαστήριο 4: Υλοποίηση Αφηρημένου Τύπου Δεδομένων: Ταξινομημένη Λίστα

ΠΛΗ111. Ανοιξη Μάθηµα 5 ο. Ουρά. Τµήµα Ηλεκτρονικών Μηχανικών και Μηχανικών Υπολογιστών Πολυτεχνείο Κρήτης

υναµικές οµές εδοµένων (συν.) Στην ενότητα αυτή θα µελετηθούν τα εξής επιµέρους θέµατα:

2.2.5 ΑΝΑΠΑΡΑΣΤΑΣΗ ΑΛΓΟΡΙΘΜΟΥ

ΠΑΝΕΠΙΣΤΗΜΙΟ ΚΥΠΡΟΥ ΤΜΗΜΑ ΠΛΗΡΟΦΟΡΙΚΗΣ. ΕΠΛ 035: οµές εδοµένων και Αλγόριθµοι για Ηλεκτρολόγους Μηχανικούς και Μηχανικούς Υπολογιστών

Διάλεξη 16: Σωροί. Στην ενότητα αυτή θα μελετηθούν τα εξής επιμέρους θέματα: - Ουρές Προτεραιότητας - Ο ΑΤΔ Σωρός, Υλοποίηση και πράξεις

Διάλεξη 26: Σωροί. Διδάσκων: Παναγιώτης Ανδρέου

ΑΝΑΠΤΥΞΗ ΕΦΑΡΜΟΓΩΝ ΣΕ ΠΡΟΓΡΑΜΜΑΤΙΣΤΙΚΟ ΠΕΡΙΒΑΛΛΟΝ

Συλλογές, Στοίβες και Ουρές

Oι βασικές πράξεις (λειτουργίες) που ορίζονται για τον τύπο στοίβα αναφέρονται παρακάτω:

Φροντιστήριο 4 Σκελετοί Λύσεων

Κατ οίκον Εργασία 2 Σκελετοί Λύσεων

Διδάσκων: Κωνσταντίνος Κώστα Διαφάνειες: Δημήτρης Ζεϊναλιπούρ

ΕΝΟΤΗΤΑ 7 ΟΥΡΕΣ ΠΡΟΤΕΡΑΙΟΤΗΤΑΣ ΣΩΡΟΙ

Διάλεξη 06: Συνδεδεμένες Λίστες & Εφαρμογές Στοιβών και Ουρών

ΠΛΗ111. Ανοιξη Μάθηµα 4 ο. Στοίβα. Τµήµα Ηλεκτρονικών Μηχανικών και Μηχανικών Υπολογιστών Πολυτεχνείο Κρήτης

Διάλεξη 17: Δυαδικά Δέντρα. Διδάσκων: Κωνσταντίνος Κώστα Διαφάνειες: Δημήτρης Ζεϊναλιπούρ

Κατ οίκον Εργασία 3 Σκελετοί Λύσεων

Στοίβες - Ουρές. Στοίβα (stack) Γιάννης Θεοδωρίδης, Νίκος Πελέκης, Άγγελος Πικράκης Τµήµα Πληροφορικής

Δομές Δεδομένων & Αλγόριθμοι

Δομές Δεδομένων. Ενότητα 6: Εφαρμογή Συνδεδεμένων Λιστών: Αλφαβητικό ευρετήριο κειμένου- Υλοποίηση ΑΤΔ Στοίβα και Ουρά με δείκτες

Ανάπτυξη εφαρμογών σε προγραμματιστικό περιβάλλον υποδειγματική διδασκαλία Κεφ. 3 Δομές Δεδομένων & αλγόριθμοι

Επιλογές και Κριτήρια Σχεδιασμού ΑΤΔ Ανεξαρτήτως από Γλώσσα Υλοποίησης 24/4/2012

Διάλεξη 08: Λίστες ΙΙ Κυκλικές Λίστες

Προγραμματισμός Ι. Δομές Δεδομένων. Δημήτρης Μιχαήλ. Ακ. Έτος Τμήμα Πληροφορικής και Τηλεματικής Χαροκόπειο Πανεπιστήμιο

Αλγόριθμοι και Δομές Δεδομένων (IΙ) (γράφοι και δένδρα)

Υλοποίηση Λειτουργιών Στοίβας Απλά(1/2)

Δομές Δεδομένων. Ενότητα 2: Στοίβες Εισαγωγή-Υλοποίηση ΑΤΔ Στοίβα με Πίνακα-Εφαρμογή Στοίβας: Αντίστροφη Πολωνική Γραφή. Καθηγήτρια Μαρία Σατρατζέμη

Κατ οίκον Εργασία 2 Σκελετοί Λύσεων

ΚΕΦΑΛΑΙΟ 3 ΔΟΜΕΣ ΔΕΔΟΜΕΝΩΝ ΚΑΙ ΑΛΓΟΡΙΘΜΟΙ

Διάλεξη 08: Λίστες ΙΙ Κυκλικές Λίστες

Σύνοψη Προηγούμενου. Λίστες (Lists) Συνδεδεμένες Λίστες: Εισαγωγή (1/2) Συνδεδεμένες Λίστες. Ορέστης Τελέλης

Αναδροµή. Σε αυτήν την (βοηθητική) ενότητα θα µελετηθούν τα εξής : Η έννοια της αναδροµής Υλοποίηση και αποδοτικότητα Αφαίρεση της αναδροµής

ΑΝΑΠΤΥΞΗ ΕΦΑΡΜΟΓΩΝ Κεφάλαιο 3 ο

Διδάσκων: Παναγιώτης Ανδρέου

ΠΑΡΑΡΤΗΜΑ: QUIZ ΔΟΜΕΣ ΔΕΔΟΜΕΝΩΝ

Διάλεξη 21η: Απλά Συνδεδεμένες Λίστες

ΠΑΝΕΠΙΣΤΗΜΙΟ ΚΥΠΡΟΥ ΤΜΗΜΑ ΠΛΗΡΟΦΟΡΙΚΗΣ. ΕΠΛ 035: οµές εδοµένων και Αλγόριθµοι για Ηλεκτρολόγους Μηχανικούς και Μηχανικούς Υπολογιστών

ιαφάνειες παρουσίασης #6 (α)

ΕΠΛ 231 Δομές Δεδομένων και Αλγόριθμοι 4-1

Οι δομές δεδομένων στοίβα και ουρά

ΕΙΣΑΓΩΓΗ ΣΤΗΝ ΠΛΗΡΟΦΟΡΙΚΗ

Διδάσκων: Παναγιώτης Ανδρέου

Δομές Δεδομένων. Ενότητα 3: Ουρές Εισαγωγή-Υλοποίηση ΑΤΔ Ουρά με πίνακα. Καθηγήτρια Μαρία Σατρατζέμη. Τμήμα Εφαρμοσμένης Πληροφορικής.

ιαφάνειες παρουσίασης #5 (β)

Τύποι Δεδομένων και Απλές Δομές Δεδομένων. Παύλος Εφραιμίδης V1.0 ( )

ΑΝΑΠΤΥΞΗ ΕΦΑΡΜΟΓΩΝ ΣΕ ΠΡΟΓΡΑΜΜΑΤΙΣΤΙΚΟ ΠΕΡΙΒΑΛΛΟΝ ΕΠΑΝΑΛΗΠΤΙΚΟ ΔΙΑΓΩΝΙΣΜΑ ΟΝΟΜΑΤΕΠΩΝΥΜΟ:

Διδάσκων: Παναγιώτης Ανδρέου

Δομές Δεδομένων & Ανάλυση Αλγορίθμων. 3ο Εξάμηνο. Ουρά (Queue) Υλοποίηση της με τη βοήθεια πίνακα.

ΑΤΕΙ ΘΕΣΣΑΛΟΝΙΚΗΣ. Δηµοσθένης Σταµάτης Τµήµα Πληροφορικής

ΚΕΦΑΛΑΙΟ 8: Αφαίρεση δεδοµένων

Διάλεξη 21: Γράφοι II - Τοπολογική Ταξινόμηση

Διάλεξη 12: Δέντρα ΙΙ Δυαδικά Δέντρα

Δομές Δεδομένων Ενότητα 4

Διάλεξη 15: Δομές Δεδομένων IV (Διπλά Συνδεδεμένες Λίστες)

Δομές Δεδομένων. Δημήτρης Μιχαήλ. Εισαγωγή. Τμήμα Πληροφορικής και Τηλεματικής Χαροκόπειο Πανεπιστήμιο

Διάλεξη 08: ΛίστεςΙΙ Κυκλικές Λίστες. Διδάσκων: Παναγιώτης Ανδρέου

Δομές Δεδομένων. Ενότητα 4: Ο ΑΤΔ Λίστα & Υλοποίηση Λίστας με σειριακή αποθήκευση- Ο ΑΤΔ Συνδεδεμένη Λίστα- Υλοποίηση ΑΤΔ Συνδεδεμένη Λίστα με πίνακα

Διάλεξη 17: Επανάληψη για την ενδιάμεση εξέταση. Διδάσκων: Παναγιώτης Ανδρέου. ΕΠΛ035 Δομές Δεδομένων και Αλγόριθμοι για Ηλ. Μηχ. Και Μηχ. Υπολ.

Διάλεξη 16: Σωροί. Στην ενότητα αυτή θα μελετηθούν τα εξής επιμέρους θέματα: - Ουρές Προτεραιότητας - Ο ΑΤΔ Σωρός, Υλοποίηση και πράξεις

Ενότητα 3: ΔΟΜΕΣ ΔΕΔΟΜΕΝΩΝ ΚΑΙ ΑΛΓΟΡΙΘΜΟΙ

ΛΙΣΤΕΣ. Ορισμός ΑΤΔ Λίστα ΑΤΔ Ακολουθιακή Λίστα Διαχείριση Δεικτών και Λιστών στη C ΑΤΔ Συνδεδεμένη Λίστα. Εφαρμογές και Χρήση Λιστών

3 ΟΥ και 9 ΟΥ ΚΕΦΑΛΑΙΟΥ

Transcript:

Βασικές Δομές Δεδομένων Στην ενότητα αυτή θα μελετηθούν τα εξής επιμέρους θέματα: Αφηρημένοι Τύποι Δεδομένων Οι ΑΤΔ Στοίβα και Ουρά Υλοποίηση των ΑΤΔ Στοίβα και Ουρά με Διαδοχική και Δυναμική Χορήγηση Μνήμης ΕΠΛ 231 Δομές Δεδομένων και Αλγόριθμοι 3-1

Αφηρημένοι Τύποι Δεδομένων Τύπος Δεδομένων: μια συλλογή αντικειμένων με μια κοινή σχέση, μαζί με ένα σύνολο πράξεων για τη δημιουργία και επεξεργασία των αντικειμένων. Αφηρημένος Τύπος Δεδομένων (ΑΤΔ): μαθηματικό μοντέλο που αποτελείται από ένα ή περισσότερα πεδία ορισμού και ένα σύνολο πράξεων για επεξεργασία των πεδίων ορισμού. Όταν μιλούμε για ένα ΑΤΔ μας ενδιαφέρει η προδιαγραφή του και πως θα τον χρησιμοποιήσουμε. Δεν μας ενδιαφέρει ο τρόπος υλοποίησής του μέσα στη μηχανή. (Η υλοποίηση ενός ΑΤΔ μπορεί να αλλάξει χωρίς να επηρεάσει την ορθότητα προγραμμάτων που τον χρησιμοποιούν.) ΕΠΛ 231 Δομές Δεδομένων και Αλγόριθμοι 3-2

Αφηρημένοι Τύποι Δεδομένων Παραδείγματα: 1. Οτύποςint μαζί με τις πράξεις +, *, /, =, είναι ένας τύπος δεδομένων. Για να τον χρησιμοποιήσουμε χρειάζεται να γνωρίζουμε το σύνολο των σχετικών πράξεων. O τρόπος αναπαράστασής του στον υπολογιστή δεν μας ενδιαφέρει. 2. Ουρά Προτεραιότητας: ένα σύνολο στοιχείων τύπου key (π.χ. key = (int,int) ) πάνω στο οποίο έχει ορισθεί μια γραμμική διάταξη, συνοδευόμενο από τις πιο κάτω πράξεις. δημιούργησε την άδεια ουρά προτεραιότητας, q, έλεγξε αν η ουρά q είναι άδεια βάλε το στοιχείο k στην ουρά q, αφαίρεσε και επίστρεψε το μικρότερο στοιχείο της q(σύμφωνα με τη γραμμική διάταξη της ουράς). Ένας ΑΤΔ μπορεί να υλοποιηθεί με πολλούς τρόπους, π.χ. μια ουρά προτεραιότητας μπορεί να υλοποιηθεί από δομές λίστας, δενδρικές δομές κλπ. ΕΠΛ 231 Δομές Δεδομένων και Αλγόριθμοι 3-3

Λίστες Λίστα: μια ακολουθία στοιχείων Λ = α 1, α 2,..., α n Αναφερόμαστε στα στοιχεία της λίστας ως κόμβους. Με Λ[i] αναφερόμαστε στο i-οστό στοιχείο της λίστας. Μήκος μιας λίστας Λ ονομάζεται ο αριθμός των στοιχείων της και συμβολίζεται ως Λ. Αν Λ = 0 τότε αναφερόμαστε στην κενή λίστα την οποία συμβολίζουμε ως. Συνοδεύοντας λίστες με ένα σύνολο πράξεων μπορούμε να ορίσουμε αφηρημένους τύπους δεδομένων. Χρήσιμες πράξεις περιλαμβάνουν τις πιο κάτω: Δημιουργία λίστας Εισαγωγή νέου κόμβου στη λίστα Εξαγωγή κόμβου από τη λίστα Εύρεση κόμβου με ορισμένη ιδιότητα Διάταξη της λίστας σύμφωνα με κάποια σχέση ΕΠΛ 231 Δομές Δεδομένων και Αλγόριθμοι 3-4

Λίστες Οι πιο σημαντικές πράξεις στον ορισμό ενός ΑΤΔ-λίστας είναι η εισαγωγή και η εξαγωγή κόμβων στα άκρα της λίστας. Με βάση την προδιαγραφή αυτών των πράξεων, διακρίνουμε δύο βασικούς τύπους λίστας που έχουν πολλές και σημαντικές εφαρμογές σε κλάδους επιστημών που χρησιμοποιούν υπολογιστικές μεθόδους. Είναιοιακόλουθες: Η στοίβα (stack) που έχει μόνο ένα άκρο προσιτό για εισαγωγές και εξαγωγές κόμβων. Η ουρά (queue) όπου γίνονται εισαγωγές στο ένα άκρο και εξαγωγές από το άλλο. Υπάρχουν και άλλοι ΑΤΔ-λίστας μικρότερης πρακτικής σημασίας, όπως ουρά με δύο άκρα, πολλαπλή στοίβα, κλπ ΕΠΛ 231 Δομές Δεδομένων και Αλγόριθμοι 3-5

Στοίβες Ορίζουμε μια στοίβα ως μια λίστα συνοδευόμενη από τις πιο κάτω πράξεις: pop MakeEmptyStack() IsEmptyStack(S) Push(x,S) Pop(S) Top(S) δημιούργησε την κενή στοίβα επέστρεψε τη λογική τιμή που εκφράζει το αν η S είναι κενή εισήγαγε τον κόμβο x στην κορυφή της στοίβας S διέγραψε τον κόμβο κορυφής της S δώσε τον κόμβο κορυφής της S ΕΠΛ 231 Δομές Δεδομένων και Αλγόριθμοι 3-6

Στοίβες Οι πράξεις αυτές προδιαγράφονται από τους εξής κανόνες: IsEmptyStack (MakeEmptyStack) = true IsEmptyStack(Push(x,S)) = false Pop(MakeEmptyStack()) = error Pop(Push(x,S)) = S πολιτική LIFO last in, first out Top(MakeEmptyStack()) = error Top(Push(x,S)) = x ΕΠΛ 231 Δομές Δεδομένων και Αλγόριθμοι 3-7

Ουρές Από μια ουρά Q πρώτο διαγράφεται το στοιχείο που εισήχθηκε πρώτο στην ουρά. Νέες εισαγωγές γίνονται στο πίσω άκρο. Ορίζουμε μια ουρά ως μια λίστα συνοδευόμενη από τις πιο κάτω πράξεις: MakeEmptyQueue() δημιούργησε την κενή ουρά <> IsEmptyQueue(Q) EnQueue (x,q) DeQueue(Q) Top(Q) επέστρεψε τη λογική τιμή που εκφράζει το αν η Q είναι κενή εισήγαγε τον κόμβο x στην ουρά Q διέγραψε τον κόμβο εξόδου της Q δώσε τον κόμβο εξόδου της Q ΕΠΛ 231 Δομές Δεδομένων και Αλγόριθμοι 3-8

Ουρές Οι πράξεις αυτές προδιαγράφονται από τους εξής κανόνες IsEmptyQueue(MakeEmptyQueue()) = true IsEmptyQueue (EnQueue(x,Q)) = false DeQueue(MakeEmptyQueue()) = error πολιτική FIFO first in, first out DeQueue (EnQueue(x,Q)) = if IsEmptyQueue( Q ) then Q else EnQueue(x, DeQueue(Q)) Top (MakeEmptyQueue ()) = error Top(EnQueue (x,q)) = if IsEmptyQueue( Q ) then x else Top(Q) ΕΠΛ 231 Δομές Δεδομένων και Αλγόριθμοι 3-9

Ουρές με Δύο Άκρα ΟΑΤΔ ουρά με δύο άκρα είναι παρόμοιος με το ΑΤΔ ουρά, με τη διαφορά ότι έχει δύο άκρα και επιτρέπει εισαγωγές και εξαγωγές και στα δύο. Μια ουρά δύο άκρων ορίζεται ως μια λίστα συνοδευόμενη από τις πιο κάτω πράξεις: MakeEmptyDeQue(), IsEmptyDeQue(Q) Insert(x, Q) Eject(Q) εισήγαγε το στοιχείο x στομπροστινόάκροτηςq διέγραψε τον κόμβο στο πίσω άκρο της Q EnQueue (x,q) εισήγαγε τον στοιχείο x στο πίσω μέρος της Q. DeQueue(Q) Front(Q) Rear(Q) διέγραψε τον κόμβο στο μπροστινό άκρο της Q δώσε τον κόμβο στο μπροστινό άκρο της Q δώσε τον κόμβο στο πίσω άκρο της Q ΕΠΛ 231 Δομές Δεδομένων και Αλγόριθμοι 3-10

Αναπαράσταση Στοίβας ΟΑΤΔ«στοίβα» μπορεί να υλοποιηθούν με διάφορες δομές δεδομένων χρησιμοποιώντας είτε στατική είτε δυναμική χορήγηση μνήμης. 1. Αναπαράσταση Στοίβας με Διαδοχική Χορήγηση Μνήμης Ο πιο απλός τρόπος είναι η χρήση μονοδιάστατου πίνακα. Χρειάζεται να γνωρίζουμε από την αρχή το μήκος της λίστας. Για την παράσταση στοίβας με στοιχεία α 1, α 2,..., α n χρειαζόμαστε ένα πίνακα Α στον οποίο θα αποθηκεύσουμε τα στοιχεία της στοίβας, Α[i-1] = α i. Πρέπει να γνωρίζουμε ανά πάσα στιγμή που βρίσκεται η κορυφή της στοίβας. Έτσι χρησιμοποιούμε μια εγγραφή με δύο πεδία 1. ένα πίνακα Α[0..n-1], και 2. μια μεταβλητή Length τύπου ακέραιος (που συγκρατεί τη θέση εισαγωγής). 0 1 2 3 4 5 Length ΕΠΛ 231 Δομές Δεδομένων και Αλγόριθμοι 3-11

Αναπαράσταση ΑΤΔ Στοίβα Ο τύπος δεδομένων που χρειάζεται για τη δομή είναι: typedef struct Stack{ type list[size]; int Length; } stack Yλοποίηση πράξεων: MakeEmpty(stack *S){ (*S).Length = 0; } Push(type x, stack *S){ if (*S).Length <size (*S).list[(*S).Length]= x; (*S).Length++; } int IsEmpty(stack *S){ return ((*S).Length == 0); } Pop(stack *S){ if!isempty(s) (*S).Length--; } type Top(stack *S){ if!isempty(s) return (*S).list[(*S).Length-1]; } ΕΠΛ 231 Δομές Δεδομένων και Αλγόριθμοι 3-12

Παράδειγμα MakeEmpty (S); Push(3,S); Push(5,S); 3 52 7 Push(7,S); Pop(S); Pop(S); Push(2,S); ΕΠΛ 231 Δομές Δεδομένων και Αλγόριθμοι 3-13

Αναπαράσταση Ουράς 2. Παράσταση Oυράς σε Διαδοχική Μνήμη Για την παράσταση μιας ουράς με στοιχεία α 0, α 1,..., α n-1 χρειαζόμαστε ένα πίνακα Α στον οποίο θα αποθηκεύσουμε τα στοιχεία της ουράς, Α[i-1] = α i, και δύο δείκτες που προσδιορίζουν τα δύο προσιτά άκρα της ουράς. Έτσι χρησιμοποιούμε μια εγγραφή με τρία πεδία 1. ένα πίνακα Α[n], 2. μια μεταβλητή front, τύπου ακέραιος, που συγκρατεί τη θέση εξόδου, και 3. μια μεταβλητή Length, τύπου ακέραιος, που συγκρατεί τo μέγεθος της ουράς. Length ΕΠΛ 231 Δομές Δεδομένων και Αλγόριθμοι 3-14

Αναπαράσταση Ουράς Για λόγους χώρου μνήμης θα πραγματοποιήσουμε την ουρά με μια κυκλική διάταξη των λέξεων της μνήμης. Δηλαδή θα θεωρούμε ότι η περιοχήμνήμηςδεναρχίζειμετηλέξηα[0] και τελειώνει με τη λέξη Α[n-1], αλλά ότι μετά την Α[n-1] ακολουθεί η Α[0]. A[n-1] A[n-2] A[0] A[1]... Έτσι μετά από μια ακολουθία εισαγωγών και εξαγωγών η ουρά μας πιθανόν να έχει την πιο κάτω μορφή όπου θεωρούμε ότι η αρχή της ουράς βρίσκεται στη θέση k και το τέλος της ουράς στη θέση 4. k ΕΠΛ 231 Δομές Δεδομένων και Αλγόριθμοι 3-15

Αναπαράσταση Ουράς Ο τύπος δεδομένων που χρειάζεται για τη δομή είναι: typedef struct Queue{ type list[size]; int front; int Length; } queue Yλοποίηση πράξεων: MakeEmpty(queue *Q){ (*Q).Length = (*Q).front = 0; } int IsEmpty(queue *Q){ return ((*Q).Length == 0); } ΕΠΛ 231 Δομές Δεδομένων και Αλγόριθμοι 3-16

Αναπαράσταση Ουράς Enqueue(type x, queue *Q){ if ((*Q).Length < size) (*Q).list[(*Q).front (*Q).Length] = x; (*Q).Length++; } Dequeue(queue *Q){ if (!IsEmpty (Q)) (*Q).Length--; (*Q).front = (*Q).front 1; } type Top(queue *Q){ if (!IsEmpty(Q) return (*Q).list[(*Q).front]; } Γράφουμε a b για (a + b)mod size και a b για (a b)mod size ΕΠΛ 231 Δομές Δεδομένων και Αλγόριθμοι 3-17

Αναπαράσταση Στοίβας 3. Παράσταση Στοίβας σε Συνδετική Μνήμη Για την παράσταση μιας στοίβας με στοιχεία α 1, α 2,..., α n χρησιμοποιούμε μια συνδεδεμένη λίστα από κόμβους. Κάθε κόμβος αποτελείται από ένα στοιχείο (στοιχεία της στοίβας) και από ένα δείκτη (προς τον επόμενο κόμβο της στοίβας). Η κορυφήτης στοίβας είναι ο πρώτος κόμβος της λίστας, Χρησιμοποιούμε μια μεταβλητή για να φυλάγουμε στοιχεία σχετικά με τη στοίβα π.χ. μέγεθος και δείκτη προς την κορυφή της στοίβας. 3 ΕΠΛ 231 Δομές Δεδομένων και Αλγόριθμοι 3-18

Αναπαράσταση Στοίβας Συνεπώς απαιτούνται οι παρακάτω δηλώσεις κόμβων: typedef struct node { type data; struct node *next; } NODE; typedef struct stack { NODE *top; int size; } STACK; Υπολείπεται η υλοποίηση των βασικών πράξεων στοίβας για αναπαράσταση με συνδεδεμένες λίστες. Βασικό ζητούμενο: όλες οι πράξεις να εκτελούνται σε χρόνο Ο(1). ΕΠΛ 231 Δομές Δεδομένων και Αλγόριθμοι 3-19

Υλοποίηση πράξεων: Αναπαράσταση Στοίβας int IsEmptyStack(STACK *S) return ((*S).size == 0) Pop(STACK *S) if ((*S).size) > 0) p = (*S).top; (*S).top = (*p).next; free(p); (*S).size--; Push(STACK *S, type x) p = (NODE *)malloc(sizeof(node)); (*p).data = x; (*p).next =(*S).top; (*S).top = p; (*S).size ++; ΕΠΛ 231 Δομές Δεδομένων και Αλγόριθμοι 3-20

Αναπαράσταση Ουράς 4. Παράσταση Ουράς σε Συνδετική Μνήμη Όπως και στην περίπτωση της στοίβας, κάθε κόμβος αποτελείται από ένα στοιχείο και ένα δείκτη (που δείχνει προς τον επόμενο κόμβο). Σε αυτή την περίπτωση χρησιμοποιούμε δύο δείκτες για υλοποίηση μιας ουράς, ο κάθε ένας από τους οποίους δείχνει στο κάθε ένα από τα προσιτά άκρα της ουράς. struct queue { int size node *front; node *back; } size front back ΕΠΛ 231 Δομές Δεδομένων και Αλγόριθμοι 3-21