Γραφήματα (Graphs) G = (V, E) Κορυφές και ακμές. μονοπάτι 1,2,3,4 κορυφή 3. ακμή. γειτονικές G 1 V(G 1 ) = {1,2,3,4,5}

Μέγεθος: px
Εμφάνιση ξεκινά από τη σελίδα:

Download "Γραφήματα (Graphs) G = (V, E) Κορυφές και ακμές. μονοπάτι 1,2,3,4 κορυφή 3. ακμή. γειτονικές G 1 V(G 1 ) = {1,2,3,4,5}"

Transcript

1 Γραφήματα (Graphs) G = (V, E) Κορυφές και ακμές 2 4 μονοπάτι,2,3,4 κορυφή 3 ακμή γειτονικές V(G ) = {,2,3,4,5 G E(G ) = {(,2), (2,3), (2,4), (3,4), (4,5) 5

2 To Δένδρο, ειδική περίπτωση γραφήματος 2 3 G μήκος μονοπατιού (διαδρομή από κόμβο έως κόμβο) κύκλος (μονοπάτι από έναν κόμβο στον εαυτό του) αν δεν υπάρχει κύκλος τότε ακυκλικό (πχ. Δένδρο) συνδεδεμένο (αν για ζεύγη κόμβων υπάρχει μονοπάτι) βαθμός κόμβου (ο αριθμός των ακμών)

3 Κατευθυνόμενο γράφημα ακμές με κατεύθυνση (μονόδρομος) 2 V(G 3 ) = {,2,3,4 3 4 E(G 3 ) = {<,2>, <2,3>, <3,4>, <4,> G 3 Ισχυρά συνδεδεμένο αν για κάθε ζεύγος κόμβων Vi, Vj υπάρχoυν κατευθυνόμενα μονοπάτια από Vi σε Vj και απόvj σε Vi. Το G3 είναι ισχυρά συνδεδεμένο κατευθυνόμενο γράφημα

4 Ο ΑΤΔ Γράφημα και οι υλοποιήσεις του Ο ΑΤΔ γράφημα G = (V, E) αποτελείται από ένα σύνολο V (κορυφές), μια σχέση Ε (ακμές) και πράξεις που επιδρούν πάνω στα δύο αυτά σύνολα.

5 Βασικές πράξεις. Δημιουργία γραφήματος: Δημιουργεί ένα κενό γράφημα. 2. Γειτονική κορυφή: Ελέγχει αν υπάρχει ακμή μεταξύ δύο κορυφών. 3. Ενημέρωση: Τροποποιεί το περιεχόμενο μιας κορυφής. 4. Ανάκτηση: Επιστρέφει το περιεχόμενο μιας κορυφής. 5. Διαγραφή κορυφής: Διαγράφει μια κορυφή από το γράφημα μαζί με τις ακμές που περιέχουν την κορυφή αυτή. 6. Διαγραφή ακμής: Διαγράφει μια ακμή από το γράφημα. 7. Εισαγωγή κορυφής: Εισάγει μια κορυφή στο γράφημα, χωρίς τη σύνδεσή της με άλλες κορυφές. 8. Εισαγωγή ακμής: Εισάγει μια ακμή στο γράφημα.

6 Υλοποίηση του ΑΤΔ Γράφημα με πίνακα G κατασκευή γειτονικού πίνακα (πίνακας γειτνίασης): αν κορυφές i,j γειτονικές A[i,j]= αλλιώς (για μη-κατευθυνόμενα οι πίνακες είναι συμμετρικοί)

7 Ο γειτονικός πίνακας ενός γραφήματος δεν είναι μονοσήμαντα ορισμένος, αφού η κατασκευή του εξαρτάται από την αρίθμηση των κορυφών του γραφήματος G Γειτονικός πίνακας κατευθυνόμενου γραφήματος

8 Υλοποίηση με Πίνακα #define plithos typedef struct { int typos_pinaka[plithos][plithos]; int arkrfon ; // ο πραγματικός αριθμός κορυφών graphima; graphima G;

9 /*Δημιουργία κενού γραφήματος (μερική απόκρυψη)*/ void dimiourgia(graphima *G){ G->arkrfon = ;

10 int geitoniki(graphima G, korifi p, korifi q){ /* Eλέγχει αν οι (p,q) είναι γειτονικές στο μη κατευθυνόμενο γράφημα G */ if( (p < ) (p > G.arkrfon-) (q < ) (q > G.arkrfon-)) return -; /* Λάθος κορυφή */ else return (G.geit_pin[p][q]);

11 int diagrafi_akmis(graphima *G, korifi p, korifi q){ /* Προ: H (p,q) είναι ακμή του μη κατευθυνόμενου γραφήματος *G. Mετά: Aν οι κορυφές p,q δεν ανήκουν στο σύνολο των κορυφών του γραφήματος *G τότε επιστρέφει-, αλλιώς αν η (p,q) είναι ακμή του γραφήματος *G τότε διαγράφεται η (p,q) από το *G και η συνάρτηση επιστρέφει, αλλιώς η συνάρτηση επιστρέφει. */ if ( (p<) (p > G->arkrfon-) (q<) (q > G->arkrfon-) ) return -; /* Λάθος κορυφές */ else if (!geitoniki(*g,p,q,)) return ; else{ G->geit_pin[p][q] = ; G->geit_pin[q][p] = ; return ;

12 int eisagogi_akmis(graphima *G, korifi p,korifi q){ /* Προ: Oι κορυφές p,q ανήκουν στο σύνολο κορυφών του *G και η ακμή (p,q) δεν ανήκει στο μη κατευθυνόμενο γράφημα. Mετά: Aν οι κορυφές p,q δεν ανήκουν στο σύνολο των κορυφών του *G τότε η συνάρτηση επιστρέφει -, αλλιώς αν η ακμή (p,q) δεν ανήκει στο σύνολο ακμών του *G τότε εισάγεται και η συνάρτηση επιστρέφει, αλλιώς η συνάρτηση επιστρέφει */ if (p<) (p > G->arkrfon-) (q<) (q > G->arkrfon-) ) return -; /* Λάθος κορυφές */ else if (geitoniki(*g, p, q)) else{ return ; G->geit_pin[p][q] = ; G->geit_pin[q][p] = ; return ;

13 int eisagogi_korifis(graphima *G, korifi *p){ /* Προ:Tο γράφημα *G δεν έχει το μέγιστο πλήθος κορυφών. Mετά: Eισάγεται στο γράφημα *G η κορυφή G->arkrfon χωρίς αυτή να συνδεθεί με άλλες κορυφές, το *p γίνεται ίσο με αυτήν και η συνάρτηση επιστρέφει. Aν το *G είχε το μέγιστο πλήθος κορυφών τότε η συνάρτηση επιστρέφει. */ korifi i; if (G->arkrfon == plithos) return ; else{ G->arkrfon++; *p = (G->arkrfon)-; /* Tελευταία κορυφή */ for (i = ; i <= *p; i++){ G->geit_pin[*p][i] = ; /*Nέα γραμμή*/ G->geit_pin[i][*p] = ; /*Nέα στήλη*/ return ;

14 int diagrafi_korifis(graphima *G, korifi p){ /* Προ : H κορυφή p ανήκει στο σύνολο κορυφών του γραφήματος *G. Mετά: Aν η κορυφή p ανήκει στο σύνολο κορυφών του γραφήματος *G τότε αυτή διαγράφεται και διαγράφονται και όλες οι ακμές που περιέχουν την κορυφή p και η συνάρτηση επιστρέφει, αλλιώς η συνάρτηση επιστρέφει. Mετά από αυτές τις διαγραφές το γράφημα έχει ως κορυφές του τις,,.., (G->arkrfon)-2. */

15 int diagrafi_korifis(graphima *G, korifi p) { korifi i,j; if ( (p<) (p > (G->arkrfon)-) ) return ; /* Λάθος κορυφή */ else { /* μετακίνηση i+ γραμμής προς τα πάνω */ for ( i = p; i <= (G->arkrfon)-2; i++) for ( j = ; j <= (G->arkrfon)-; j++) G->geit_pin[i][j]=G->geit_pin[i+][j]; /* μετακίνηση i+ στήλης προς τα αριστερά */ for ( i = p; i <= (G->arkrfon)-2; i++) for ( j = ; j <= (G->arkrfon)-2; j++) G->geit_pin[j][i] =G->geit_pin[j][i+]; G->arkrfon--; return ;

16 Υλοποίηση του ΑΤΔ Γράφημα με συνδεδεμένες λίστες (κόμβοι και δείκτες) 2 4 μονοπάτι,2,3,4 κορυφή 3 ακμή γειτονικές G 5

17 Πίνακας δεικτών Α. Λίστα γειτονικών κορυφών του G κόμβοι κεφαλές κόμβοι γειτονικών κορυφών

18 A 2 B E 5 G 5 C D 3 4

19 2 3 4 δείκτες.... Λίστα γειτονικών κορυφών του G 5 A B C D κόμβοι κεφαλές Data Data Data Data κόμβοι γειτονικών κορυφών.. B C. C.. B D. D E. 5. E Data

20 Οι δηλώσεις στην C για την παράσταση ενός γραφήματος με λίστα γειτονικών κορυφών είναι οι ακόλουθες : #define plithos_korifon... typedef... typos_dedomenon; /* τ.δ.κορυφών */ typedef int arithmos_korifis; typedef struct korifi *kdktis; typedef struct korifi{ arithmos_korifis arkorifis; kdktis epomenos ; ; /* κόμβος κορυφή */

21 typedef struct kefali *kefdktis; typedef struct kefali{ typos_dedomenon dedomena; kdktis epomenos; ; /* κόμβος κεφαλή ένας για κάθε κορυφή*/ typedef struct{ kefdktis pinakas[plithos_korifon]; int k; /* αριθμός κορυφών */ graphima; graphima G;

22 Ορθογώνια Λίστα (αραιοί πίνακες 5-8%!=) Α Β C E D

23 κόμβοι κεφαλές Απεικόνιση Αραιού Πίνακα, ως γράφημα G

24 Υλοποίηση Γραφήματος με Λίστα Ακμών Α Β C E D G5

25 λίστα κορυφών G. Α.. B.. C.. D.. E. <ΑΒ> <DD> <CB> λίστα ακμών <ΑC> <BC>.. <CD>.... <ΑE>

26 typedef... typos_stoixeiou; /* δεδομένα κορυφής */ typedef struct korifi *kdktis; typedef struct akmi *adktis; typedef struct korifi { typos_stoixeiou dedomena; kdktis epomenos; /* επόμενος λίστας κορυφών*/ adktis kefali; /* δείκτης λίστας ακμών */ ; typedef struct akmi { typos_stoixeiou dedomena; /* δεδομένα ακμής π.χ βάρος, απόσταση*/ kdktis akro; /* άκρο ακμής */ adktis epomenos; /* επόμενος λίστας ακμών */ ; typedef kdktis graphima; graphima G;

27 /*Δημιουργία κενού γραφήματος*/ void dimiourgia(graphima *G){ *G = NULL; void enimerosi(typos_stoixeiou stoixeio, kdktis p){ /* Mετά:Eισάγει το stoixeio στον κόμβο που δείχνει ο p. */ p->dedomena = stoixeio; typos_stoixeiou anaktisi(kdktis p){ /* Mετά: H συνάρτηση επιστρέφει το περιέχομενο του κόμβου που δείχνει δείκτης p. */ return (p->dedomena);

28 int geitoniki(kdktis p, kdktis q){ int telos; adktis trexon; /*για τη σάρωση της λίστας ακμών */ int geit=; trexon = p->kefali; /* αφετηρία από την κεφαλή */ telos = ; while (!telos){ if (trexon == NULL) /* τέλος λίστας ακμών */ telos = ; else if ( trexon->akro == q ){ /* βρέθηκε */ telos = ; geit = ; else /*επόμενος κόμβος λίστας ακμών */ trexon = trexon->epomenos; return geit;

29 void diagrafi_korifis(kdktis p,graphima *G){ /* Mετά: H κορυφή που δείχνει ο p διαγράφεται */ kdktis trexon; trexon = *G; /* διατρέχει τη λίστα κορυφών */ while (!keni (trexon)){ /* δεν εξετάζεται η λίστα του p */ if (trexon! = p) /* διαγραφή της (trexon,p)*/ diagrafi_komvou(p,&(trexon->kefali)); proxorise (&trexon)/* στην επόμενη κορυφή*/ /* διαγραφή της λίστας ακμών της p */ diagrafi_listas(&(p->kefali)); /* βοηθητική */ diag_kor(p,g); /*διαγραφή κορυφής p */

30 void diagrafi_komvou(kdktis v, adktis *kefali) /* Mετά: Eντοπίζει και διαγράφει τον κόμβο της λίστας ακμών που ξεκινά απο τον *kefali του οποίου το πεδίο akro είναι ίσο με v. */ adktis pros; if (*kefali!= NULL){ if (((*kefali)->akro) == v) /* Διαγραφή του κόμβου */ { pros = *kefali; *kefali = (*kefali)->epomenos; free(pros); else diagrafi_komvou(v, &((*kefali)->epomenos));

31 void diagrafi_listas(adktis* kefali){ /* Mετά: Διαγράφει όλους τους κόμβους μιας λίστας ακμών ξεκινώντας από την κεφαλή. */ if (*kefali!=null){ diagrafi_listas(&((*kefali)->epomenos)); free (*kefali); *kefali = NULL;

32 void eisagogi_korifis(graphima *G, typos_stoixeiou stoixeio) {/* Mετά: Eισάγεται ένας νέος κόμβος στην αρχή της λίστας κορυφών με δεδομένα stoixeio */ kdktis p; p = malloc(sizeof(struct korifi)); /* Συνδέει το νέο κόμβο με την κεφαλή της λίστας κορυφών του *G */ p->dedomena = stoixeio; p->epomenos = *G; p->kefali = NULL; /* Λίστα ακμών του p είναι κενή*/ /* O κόμβος που δείχνει ο p είναι η νέα κεφαλή της λίστας κορυφών του *G */ *G = p;

33 Εισαγωγή Ακμής: μη κατευθυνόμενο (όπως εισαγωγή αρχή λίστας) p q

34 void eisagogi_akmis(kdktis p,kdktis q){ /* Mετά: Eισάγεται μια ακμή μεταξύ των κορυφών που δείχνουν οι p και q, σε ένα μη κατευθυνόμενο γράφημα. */ adktis pros; if (!geitoniki(p,q)){ pros = p->kefali; p->kefali = malloc(sizeof(struct akmi)); /* Εισαγωγή στην αρχή & σύνδεση με q */ p->kefali->akro = q; p->kefali->epomenos = pros; /* Eπαναλαμβάνονται τα παραπάνω για το q */ pros = q->kefali; q->kefali = malloc(sizeof(struct akmi)); q->kefali->akro = p; q->kefali->epomenos = pros;

35 Διαδρομή (ή Αναζήτηση) Γραφημάτων Διαδρομή πρώτα κατά βάθος Διαδρομή πρώτα κατά πλάτος Διαδρομή πρώτα κατά βάθος Α B C D E F H G Μια διαδρομή πρώτα κατά βάθος είναι ΑBEFHCDG

36 αφετηρία B F Μια πρώτα κατά βάθος σειρά, ξεκινώντας από την κορυφή Α, είναι : ABFIHGCDE C G αφετηρία A I D H E Ξεκινώντας από την Β ποτέ σε Α και Ε. Πρέπει όμως να επισκεφτούμε όλες.

37 Αλγόριθμος Διαδρομής πρώτα κατά βάθος (ισχυρά συνδεδεμένου) Επισκέπτεται όλες τις κορυφές ενός γραφήματος που είναι συνδεδεμένες με την κορυφή v από την οποία ξεκινά, με την πρώτα κατά βάθος αναζήτηση. Επίσκεψη της αρχικής κορυφής v. 2. Για κάθε γειτονική κορυφή w της v γίνονται τα εξής: Αν δεν έχουμε επισκεφτεί την w, εφαρμόζεται ο αλγόριθμος της αναζήτησης πρώτα κατά βάθος με αρχική κορυφή την w.

38 2 προβλήματα Π. Ενα γράφημα μπορεί να περιέχει κύκλους, πράγμα που σημαίνει ότι είναι δυνατόν να επισκεφθούμε μία κορυφή περισσότερες από μία φορές. Για αυτό μαρκάρουμε τις κορυφές που επισκεπτόμαστε και ελέγχουμε αν τις έχουμε ξαναεπισκεφθεί. Π2. Το άλλο φαινόμενο που μπορεί να παρουσιαστεί είναι εκείνο του μη συνδεδεμένου (για μη κατευθυνόμενο) ή μη ισχυρά συνδεδεμένου (για κατευθυνόμενο) γραφήματος. Για αυτό ξεκινάμε Διαδρομή από κάθε κορυφή του γραφήματος και αν δεν την έχουμε ξαναεπισκεφθεί ξεκινάμε νέα Διδρομή. Η Διαδρομή πρώτα κατά βάθος περιγράφεται από τα παρακάτω δυο υποπρογράμματα σε ψευδογλώσσα για να καλύπτει αφαιρετικά και τις τρεις υλοποιήσεις των γραφημάτων. Στην συνέχεια τα εξειδικεύουμε για κάθε υλοποίηση.

39 int episkeftike[plithos]; /* Πίνακας Επισκέψεων */ /*Προ: Το γράφημα G έχει δημιουργηθεί. Μετά: Το υποπρόγραμμα episkepsi έχει εκτελεστεί για κάθε κορυφή του γραφήματος G με την πρώτα κατά βάθος σειρά. Χρήση: Το υποπρόγραμμα diadromi παράγει την πρώτα κατά βάθος σειρά των κορυφών.*/ /* ψευδοκώδικας για όλες τις υλοποιήσεις*/ void vathos(graphima G){ korifi k; for all k in G do /* ψευδοκώδικας */ episkeftike[k] = ; for all k in G do /* ψευδοκώδικας */ if (!episkeftike[k]) diadromi_vathos(k);

40 /*Προ: k είναι κορυφή του γραφήματος G. Μετά: Εχει εκτελεστεί η πρώτα κατά βάθος διαδρομή, με τη χρήση του υποπρογράμματος episkepsi για την k και για όλες τις γειτονικές της κορυφές.*/ /* ψευδοκώδικας για όλες τις υλοποιήσεις*/ void diadromi_vathos(korifi k){ korifi w; episkepsi(k); episkeftike[k] = ; for all w γειτονικό to k do /* ψευδοκώδικας */ if (!episkeftike[w]) diadromi_vathos(w);

41 Εξειδίκευση: η υλοποίηση της Διαδρομής πρώτα κατά βάθος στην περίπτωση όπου το γράφημα παριστάνεται με γειτονικό πίνακα. int episkeftike[plithos]; /*Προ: Εχει δημιουργηθεί ο γειτονικός πίνακας. Μετά: Επίσκεψη όλων των κορυφών του γραφήματος με τη μέθοδο της αναζήτησης πρώτα κατά βάθος*/ void vathosp(graphima G){ korifi i; for (i=; i<=(g.arkrfon-); i++) episkeftike[i] = ; for (i=; i<=(g.arkrfon-); i++) if (!episkeftike[i]) diadromi_vathosp(g,i);

42 /*Προ: i είναι μια κορυφή του γραφήματος. Μετά: Η επίσκεψη της κορυφής i και των γειτονικών της έχειτελειώσει με την αναζήτηση πρώτα κατά βάθος*/ void diadromi_vathosp(graphima G, korifi i){ int j; episkepsi(i); /*επίσκεψη της i κορυφής*/ episkeftike[i] = ; for (j=; j<= G.arkrfon-; j++) if (geitoniki(i,j,g) && (!episkeftike[j])) diadromi_vathosp(g,j);

43 Εξειδίκευση: το γράφημα παριστάνεται με τη λίστα ακμών Κάθε κόμβος περιέχει ένα boolean πεδίο episkeftike, το οποίο αρχικά έχει τεθεί ίσο με false για κάθε κορυφή. Η diadromi τροποποιείται ως εξής:

44 void diadromi_vathosla(kdktis p){ /* Ο δείκτης p δείχνει την κορυφή αφετηρίας */ adktis trexon; kdktis q; episkepsi(p); p->episkeftike = ; trexon=p->kefali; while (trexon!=null){ q=trexon->akro; /* η q γειτονική της p */ if (!(q->episkeftike)) diadromi_vathosla(q); trexon = trexon->epomenos;

45 Πολυπλοκότητα Διαδρομής κατά βάθος Γειτονικός Πίνακας : Ο(n 2 ), επειδή Ο(n) για γειτονικές x n Λίστα γειτονικών κορυφών : Ο(e) (το πολύ 2e κόμβοι) Λίστα ακμών : Ο(n+e) Συνήθως e << n 2 Οι υλοποιήσεις με λίστες έχουν πιο αποδοτικές αναζητήσεις. Η υλοποίηση με πίνακα χρησιμοποιείται σε αλγεβρικούς υπολογισμούς με πίνακες (μετάβασης).

46 Αναζήτηση πρώτα κατά πλάτος Η αναζήτηση πρώτα κατά πλάτος ενός γραφήματος είναι ανάλογη με την επίσκεψη των κόμβων ενός δυαδικού δέντρου κατά επίπεδα. Αν κατά τη διαδρομή αυτή επισκέφτηκε η κορυφή v, τότε στη συνέχεια επισκέπτονται όλες οι γειτονικές της κορυφές τοποθετώντας τις γειτονικές τους κορυφές σε μια λίστα (ουρά) αναμονής προκειμένου να επισκεφτούν, αφού πρώτα επισκεφτούν όλες οι γειτονικές κορυφές της v.

47 Αναζήτηση πρώτα κατά πλάτος A Β C D E F G H A B C D E F G H

48 B F C G αφετηρία A D I H E A B D E F C H G I B F G I H C D A και Ε;

49 Ο αλγόριθμος της αναζήτησης πρώτα κατά πλάτος είναι παρόμοιος με εκείνον της αναζήτησης πρώτα κατά βάθος με τη διαφορά ότι τώρα προστίθεται η δημιουργία της ουράς των κορυφών και καλεί diadromi_platos. typedef korifi typos_stoixeiou; typos_oura oura_korifon; int episkeftike[plithos]; void platos(graphima G){ korifi k; for all k in G do episkeftike[k] = ; dimiourgia(&oura_korifon); for all k in G do if (!episkeftike[k]) diadromi_platos(k);

50 Όλες οι αλλαγές βρίσκονται στον αλγόριθμο του τρόπου επίσκεψης των κορυφών. Πιο συγκεκριμένα ο αλγόριθμος της διαδρομής των κορυφών του γραφήματος τροποποιείται στον παρακάτω:

51 Επαναληπτικός αλγόριθμος void diadromi_platos(korifi k){ /*Προ: k είναι η κορυφή του γραφήματος. Μετά: Έχει εκτελεστεί η κατά πλάτος διαδρομή */ korifi w,i; episkeftike[k] = ; prosthesi(&oura_korifon,k); while (!keni(oura_korifon)){ apomakrynsi(&oura_korifon,&i); episkepsi(i); for all w adjacent to i do /* ψευδοκώδικας */ if (!episkeftike[w]){ episkeftike[w] = ; prosthesi(&oura_korifon,w);

52 Εξειδίκευση: το γράφημα παριστάνεται με τη λίστα ακμών, τότε υποθέτουμε ότι κάθε κόμβος περιέχει ένα boolean πεδίο episkeftike, το οποίο αρχικά έχει τεθεί ίσο με false για κάθε κορυφή. Η δε διαδρομή τροποποιείται ως εξής: /*Ο δείκτης p δείχνει την κορυφή-αφετηρία. Προ: Το γράφημα G έχει δημιουργηθεί. Μετά: Εχει εκτελεστεί η κατά πλάτος διαδρομή όλων των κορυφών του γραφήματος. Χρήση: Οι βασικές πράξεις της ουράς.*/

53 void diadromi_platosla(kdktis p){ adktis trexon; kdktis q,i; p->episkeftike = ; prosthesi(&oura_korifon, p); while (!(keni(oura_korifon))){ apomakrynsi(&oura_korifon, &i); episkepsi(i); trexon=i->kefali; while (trexon!=null){ q=trexon->akro;/* q γειτονική p*/ if (!(q->episkeftike)){ q->episkeftike = ; prosthesi(&oura_korifon,q); trexon=trexon->epomenos;

54 Δέντρα Επικάλυψης (Spanning Trees) Ενα δέντρο επικάλυψης για ένα γράφημα G, είναι ένα δέντρο που έχει δημιουργηθεί από μερικές ακμές του G έτσι ώστε να περιέχει όλες τις κορυφές του. Με άλλα λόγια ένα δέντρο επικάλυψης είναι ένα γράφημα με το ελάχιστο πλήθος ακμών που επιτρέπει την επικοινωνία μεταξύ οποιονδήποτε κορυφών του γραφήματος.

55 Ενα δέντρο επικάλυψης με πρώτα κατά βάθος επίσκεψη των κορυφών του. Αφετηρία η κορυφή a. b g a e i h d f j

56 b g αφετηρία a e i c h d f j

57 Στη συνέχεια η vathos τροποποιείται κατάλληλα για τον εντοπισμό των ακμών ενός πρώτα κατά βάθος δέντρου επικάλυψης. /*Δημιουργεί ένα κατά βάθος δέντρο επικάλυψης*/ void vathos_spantree(graphima G){ kdktis p; adktis e; p = G; /*Αρχικές τιμές - δίνονται αρχικές τιμές σε όλα τα σημάδια επισκέπτονται όλες οι κορυφές του G και σημαδεύεται η κάθε ακμή ώστε αρχικά να μην ανήκειστο δέντρο επικάλυψης*/ συνέχεια

58 while (p!=null){ /*αρχικά οι κορυφές δεν έχουμε επισκεφτεί p->episkeftike = ; e = p->kefali; /*επισκέπτεται τη λίστα ακμών για κάθε κορυφή καισημαδεύεται η κάθε ακμή, ώστε αρχικά να μην ανήκει στο δέντρο επικάλυψης*/ while (e!=null){ e->simadi = ; e = e->epomenos; p = p->epomenos; p = G; vathos_dimiourgia(p);

59 void vathos_dimiourgia(kdktis p){ adktis trexon; kdktis q; p->episkeftike = ; trexon = p->kefali; while (trexon!=null){ q= trexon->akro; if (!(q->episkeftike)){ /* σημαδεύεται η ακμή του δέντρου*/ trexon->simadi = ; /*θα μπορούσαμε να τυπώσουμε την ακμή του δέντρου στο σημείο*/ vathos_dimiourgia(q); trexon = trexon->epomenos;

60 Με όμοιο τρόπο τροποποιείται η platos και κατασκευάζεται ένα πρώτα κατά πλάτος δέντρο επικάλυψης ενός γραφήματος G. void platos_spantree(graphima G){ /*Δημιουργεί ένα κατά πλάτος δέντρο επικάλυψης. */ typos_ouras oura; kdktis n,m; adktis trexon; /*Tο πεδίο episkeftike κάθε κορυφής true */ n = G; while (n!=null){ n->episkeftike = ; trexon = n->kefali; while (trexon!=null){ trexon->simadi = ; trexon = trexon->epomenos; n = n->epomenos; συνέχεια

61 dimiourgia(&oura); /*Το ξεκίνημα από την κεφαλή της λίστας κορυφών*/ n = G; prosthesi(&oura,n); n->episkeftike = ; while (!keni(oura)){ apomakrynsi(&oura,&n); /* επισκέπτεται η λιστά ακμών */ trexon = n->kefali; while (trexon!=null){ m = trexon->akro; if (!(m->episkeftike)){ prosthesi(&oura,m); m->episkeftike = ; trexon->simadi = ; trexon = trexon->epomenos;

62 Ενα πρώτα κατά πλάτος δέντρο επικάλυψης του γραφήματος. Αφετηρία η κορυφή a. b g αφετηρία a e i c h d f j

63 Εφαρμογές Γραφημάτων Μεταβατικό γράφημα : Γενικά : Aν Αν Αi, j true k and Ak, j A i, v μήκους 2 i, v j v E(G) true μονοπάτι i j i 2 j i vk v j A i, and A,j or A i,2 and A 2,j or..... or A i,n and A n,j true μονοπάτι μήκους 2 v v v ή v v v ή...

64 ή A l Α A (2) A A () () n k A k Ak, j A i, l-, l 2, 3, 4,... Υπάρχει μονοπάτι μήκους <= 3 ; P A () A (2) A (3) Υπαρξη μονοπατιού P A () A (2) A (3)... A (n)

65 Α Β C E D Γειτονικός πίνακας

66 A A A () () (2) ή A 2 Μεταβατικός πίνακας 2 βημάτων

67 Μεταβατικός Πίνακας / Γράφημα Γράφημα που συνδέει κορυφές που γειτνιάζουν με οποιοδήποτε αριθμό μεταβάσεων (..n). Και ο πίνακας γειτνίασής του λέγεται μεταβατικός πίνακας. Π.χ. για το παραπάνω γράφημα ο μεταβατικός πίνακας είναι: Ο(n 4 ) P=A\/A \/A \/A \/A

68 Αλγόριθμος Warshall Μεταβατικού Πίνακα O(n 3 ) P k [i, j] = /* TRUE */ Αν υπάρχει μονοπάτι από την i στην j το οποίο να μην διέρχεται από καμία κορυφή μεγαλύτερη του k.

69 P k+ [i, j] = /*true*/ AN. P k [i, j] = /*true*/ ή 2. P k [i, k+] = και P k [k+, j] = Τα παραπάνω ισοδυναμούν με P k+ [i, j] = (P k [i, j] (P k [i, k+] && P k [k+, j])); ή αναλυτικότερα for (i=;i<=n;i++) for (j=;j<=n;j++) P k [i, j] = P k- [i, j] (P k- [i, k] && P k- [k, j]);

70 Απλοποιώντας τα παραπάνω λαμβάνουμε P k = P k -; for (i=;i<=n;i++) if (P k- [i, k]) for (j=; j<=n; j++) P k [i, j] := P k- [i, j] P k- [k, j];

71 και τελικά : P k = P k-; for (i=;i<=n;i++) if (P k- [i, k]) for (j=;j<=n;j++) if (P k- [k, j]) P k [i, j] = ; Ισχύει P [i,j] = A[i,j]

72 void metavatikos_pinakas(geit_pin A, geit_pin P){ korifi i,j,k; geit_pin PP; for (i=; i <= plithos-; i++) for (j = ; j <= plithos-; j++) P[i][j]=A[i][j]; for (k=; k <= plithos-; k++){ for (i = ; i <= plithos-; i++) for (j = ; j <= plithos-; j++) PP[i][j]=P[i][j]; for (i=; i <= plithos-; i++) if (PP[i][k]) for (j=; j <= plithos-; j++) if (PP[k][j]) P[i][j] = ;

73 Το συντομότερο μονοπάτι σε ένα κατευθυνόμενο γράφημα: Ο Αλγόριθμος του Dijkstra Μπορούμε να φανταστούμε το G σαν μια απεικόνιση αεροπορικών γραμμών, στην οποία κάθε κορυφή παριστάνει μια πόλη και το βάρος σε κάθε ακμή το κόστος της πτήσης από μια πόλη σε μιαν άλλη. Το πρόβλημά μας είναι η εύρεση μιας διαδρομής από την πόλη v στην πόλη w έτσι ώστε το συνολικό κόστος (απόσταση) να είναι ελάχιστο.

74 Ένα κατευθυνόμενο γράφημα με βάρη

75 Ας θεωρήσουμε το κατευθυνόμενο γράφημα του παραπάνω σχήματος. Αν υποτεθεί ότι η κορυφή είναι η πηγή, τότε το πρόβλημά μας είναι η εύρεση του συντομότερου μονοπατιού από την κορυφή προς όλες τις άλλες κορυφές του γραφήματος. Παράσταση με πίνακα Α όπου Α[i][j] είναι το κόστος μετάβασης από την i στην j. Αν δεν υπάρχει ακμή, Α[i][j]=. Διατηρεί σύνολο S με κορυφές των οποίων η συντομότερη διαδρομή από την κορυφή-πηγή είναι γνωστή. Σε κάθε βήμα προσθέτει μια κορυφή στο S. Πίνακας D (Δ) περιέχει κόστος (μήκος) για κάθε κορυφή του S. Πίνακας P (Δ) περιέχει το μονοπάτι - προηγούμενη κάθε κορυφής του S. Άπληστος αλγόριθμος.

76 Αλγόριθμος του Dijkstra /* Υπολογίζει το κόστος του συντομότερου μονοπατιού από την κορυφή μέχρι μια οποιαδήποτε κορυφή ενός κατευθυνόμενου γραφήματος */ () S = {; /*Το σύνολο S περιέχει την κορυφή */ (2) for i=2,n do D[i] = A[,i]; {Αρχικές τιμές του D (3) for i=,n do P[i] = αν δεν υπάρχει ακμή από την προς την i P[i] = αν υπάρχει ακμή από την προς την i (4) for i =..n- do { (5) Διάλεξε μια κορυφή w εκτός S τέτοια ώστε η D[w] να είναι ελάχιστη (6) Πρόσθεσε την w στο S (7) Για κάθε κορυφή v εκτός S να ελεγχθεί αν η απόσταση απο την στην v μπορεί να συντομευθεί διαμέσου της w. Αν ναι, να ενημερωθεί η αντίστοιχη τιμή του πίνακα D. () D[v] = min (D[v], D[w] + A[w,v]) (2) Αν D[w]+A[w,v] < D[v] τότε P[v]=w

77 S={ min d=3 d= d 3 5 d=4 4 d=5 4 Επανάληψη s w D[2] D[3] D[4] D[5] D[6] αρχική { {,

78 S={, 2 d=3 d= d=7 3 5 d=4 min d=5 4 Επανάληψη s w D[2] D[3] D[4] D[5] D[6] {, {,2,

79 d=3 d= 2 6 S={, 2, d= min 4 d=5 d=4 Επανάληψη s w D[2] D[3] D[4] D[5] D[6] 2 {,2, {,2,5,

80 S={, 2, 5, 4 d=3 d= min d= d=5 d=4 Επανάληψη s w D[2] D[3] D[4] D[5] D[6] 3 {,2,5, {,2,5,4,

81 d=3 d= S={, 2, 5, 4, 3, 6 d= d=5 d=4 Επανάληψη s w D[2] D[3] D[4] D[5] D[6] 4 {,2,5,4, {,2,5,4,3,

82 s w D[2] D[3] D[4] D[5] D[6] αρχική { {, {,2, {,2,5, {,2,5,4, {,2,5,4,3, Αν αλλάξει D[v] λόγω w P[v]=w. Εδώ Αλλαγές για w=2,4,3 P[3]=2, P[3]=4,P[6]=3 9 P[] P[2] P[3] P[4] P[5] P[6]

83 Πολυπλοκότης : Ο(n 2 ) w Υποθετικά συντομότερο μονοπάτι S x Ο αλγόριθμος του Dijkstra υλοποιείται στο παρακάτω πρόγραμμα όπου χρησιμοποιείται ο πίνακας γειτονικών κορυφών για την παράσταση του γραφήματος.

84 #include <stdio.h> #define plithos 5 #define infinity 2 /* τιμή όπου δεν υπάρχει ακμή */ #define min_stoixeio #define max_stoixeio plithos- #define megisto_plithos max_stoixeio-min_stoixeio+ typedef int typos_synolou[megisto_plithos]; typedef int korifi; typedef int typos_pinaka[plithos][plithos]; typedef struct { typos_pinaka geit_pin; int arkrfon; graphima; συνέχεια

85 void Dimiourgia_graphimatos(graphima *G); void Diavasma_graphimatos(graphima *G); void Ektyposi_graphimatos(graphima G); void Dijkstra(graphima G); void Synolo_dimiourgia(typos_synolou synolo); int Synolo_eisagogi(int stoixeio, typos_synolou synolo); int Synolo_melos(int stoixeio, typos_synolou synolo); main(){ graphima G; printf("\n Δώστε το πλήθος των κορυφών: "); scanf("%d",&(g.arkrfon)); Dimiourgia_graphimatos(&G); Diavasma_graphimatos(&G); Ektyposi_graphimatos(G); Dijkstra(G);

86 void Dimiourgia_graphimatos(graphima *G){ /* Όλα τα στοιχεία του geit_pin έχουν τιμή infinity */ int i,j; for (i=; i<=(g->arkrfon)-; i++) for (j=; j<=(g->arkrfon)-; j++) (G->geit_pin)[i][j] = infinity;

87 void Diavasma_graphimatos(graphima *G){ /* Προ: έχει δημιουργηθεί ο geit_pin χωρίς ακμές. Μετά: Έχει δημιουργηθεί ο geit_pin με ακμές.*/ korifi i,j; int kostos; printf("\nδώστε τα στοιχεία του γραφήματος"); printf("\nδώστε i,j και kostos.\n\n"); scanf ("%d %d %d",&i,&j,&kostos); while (i!= plithos+){ if ( (i>=) && (i<(g->arkrfon)) &&(j>=) &&(j<(g->arkrfon)) &&(kostos>=)&&(kostos < infinity)) (G->geit_pin)[i][j] = kostos; else{ printf("\nλάθος δεδομένα. Ξαναδώστε τα"); scanf ("%d %d %d", &i, &j, &kostos);

88 void Ektyposi_graphimatos(graphima G){ /*Προ : Έχει δημιουργηθεί ο γειτονικός πίνακας. Μετά: Για κάθε κορυφή έχει τυπωθεί μια γραμμή στην οποία εμφανίζονται οι κορυφές με τις οποίες είναι συνδεδεμένη*/ korifi i,j; for (i=; i <= G.arkrfon-; i++){ printf("γραμμή %2d ", i); for (j=; j <= G.arkrfon-; j++) printf ("%8d",G.geit_pin[i][j]); printf ("\n"); printf ("\n");

89 /* Προ : Ένα κατευθυνόμενο γράφημα με βάρη Μετά: Εύρεση του συντομότερου μονοπατιού και επιστροφή του αποτελέσματος στον πίνακα D. */ void Dijkstra(graphima G){ typos_synolou S; /* το σύνολο ειδικών κορυφών*/ korifi i,j,w; int elaxisti_apostasi; int apostasi[plithos]; int monopati[plithos]; dimiourgia(s); eisagogi(,s); /* Αρχικές τιμές για τα συντομότερα μονοπάτια εφόσον υπάρχουν ακμές από την κορυφή */ for (j=; j <= G.arkrfon-; j++){ apostasi[j] = G.geit_pin[][j]; if (G.geit_pin[][j] == infinity) monopati[j] = -; else monopati[j] = ; συνέχεια

90 for ( i = ; i <= G.arkrfon-; i++){ /* Επιλογή μιας κορυφής w στο V-S : apostasi[w]=min */ elaxisti_apostasi = infinity; for (j = ; j <= G.arkrfon-; j++) if ( (!melos(j,s)) &&(apostasi[j]<elaxisti_apostasi)){ elaxisti_apostasi = apostasi[j]; w = j; eisagogi(w,s); /* Πρόσθεση της w στο S */ /*Ενημέρωση των τιμών για τον πίνακα apostasi */ for (j = ; j <= G.arkrfon-; j++) if ( (!melos(j,s)) &&( apostasi[w]+(g.geit_pin)[w][j]) < (apostasi[j])){ apostasi[j]= apostasi[w]+(g.geit_pin)[w][j]; monopati[j] = w; for (i=; i <= G.arkrfon-; i++) printf("%d %d %d\n",i,apostasi[i],monopati[i]);

Γραφήματα (Graphs) Κατευθυνόμενο γράφημα ακμές με κατεύθυνση (μονόδρομος) G = (V, E) Κορυφές και ακμές. μονοπάτι 1,2,3,4 κορυφή 3

Γραφήματα (Graphs) Κατευθυνόμενο γράφημα ακμές με κατεύθυνση (μονόδρομος) G = (V, E) Κορυφές και ακμές. μονοπάτι 1,2,3,4 κορυφή 3 G = (V, E) Κορυφές και ακμές V(G ) = {,,3,, Γραφήματα (Graphs) G E(G ) = {(,), (,3), (,), (3,), (,) μονοπάτι,,3, κορυφή 3 ακμή γειτονικές 3 Κατευθυνόμενο γράφημα ακμές με κατεύθυνση (μονόδρομος) V(G 3

Διαβάστε περισσότερα

Γραφήματα (Graphs) To Δένδρο, ειδική περίπτωση γραφήματος. G = (V, E) Κορυφές V και ακμές E G 2 4. μονοπάτι 1, 2, 3, 4 κορυφή 3

Γραφήματα (Graphs) To Δένδρο, ειδική περίπτωση γραφήματος. G = (V, E) Κορυφές V και ακμές E G 2 4. μονοπάτι 1, 2, 3, 4 κορυφή 3 G = (V, E) Κορυφές V και ακμές E V(G ) = {,,3,, Γραφήματα (Graphs) G E(G ) = {(,), (,3), (,), (3,), (,) μονοπάτι,, 3, κορυφή 3 ακμή γειτονικές To Δένδρο, ειδική περίπτωση γραφήματος G 3 6 7 μήκος μονοπατιού

Διαβάστε περισσότερα

Δομές Δεδομένων και Τεχνικές Προγραμματισμού Ενότητα 7: ΑΤΔ Γράφημα. Ιωάννης Κοτρώνης Σχολή Θετικών Επιστημών Τμήμα Πληροφορικής και Τηλεπικοινωνιών

Δομές Δεδομένων και Τεχνικές Προγραμματισμού Ενότητα 7: ΑΤΔ Γράφημα. Ιωάννης Κοτρώνης Σχολή Θετικών Επιστημών Τμήμα Πληροφορικής και Τηλεπικοινωνιών Δομές Δεδομένων και Τεχνικές Προγραμματισμού Ενότητα 7: ΑΤΔ Γράφημα Ιωάννης Κοτρώνης Σχολή Θετικών Επιστημών Τμήμα Πληροφορικής και Τηλεπικοινωνιών Σκοποί ενότητας Να ορίσει τον ΑΤΔ Γράφημα. Να σχεδιάσει

Διαβάστε περισσότερα

Γραφήματα (Graphs) G = (V, E) Κορυφές V και ακμές E. μονοπάτι 1, 2, 3, 4 κορυφή 3. ακμή. γειτονικές G 1 V(G 1 ) = {1,2,3,4,5}

Γραφήματα (Graphs) G = (V, E) Κορυφές V και ακμές E. μονοπάτι 1, 2, 3, 4 κορυφή 3. ακμή. γειτονικές G 1 V(G 1 ) = {1,2,3,4,5} Γραφήματα (Graphs) G = (V, E) Κορυφές V και ακμές E 2 4 μονοπάτι, 2, 3, 4 κορυφή 3 ακμή γειτονικές V(G ) = {,2,3,4,5 G E(G ) = {(,2), (2,3), (2,4), (3,4), (4,5) 5 To Δένδρο, ειδική περίπτωση γραφήματος

Διαβάστε περισσότερα

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

ΠΛΗ111. Ανοιξη 2005. Μάθηµα 10 ο. Γράφοι. Τµήµα Ηλεκτρονικών Μηχανικών και Μηχανικών Υπολογιστών Πολυτεχνείο Κρήτης ΠΛΗ111 οµηµένος Προγραµµατισµός Ανοιξη 2005 Μάθηµα 10 ο Γράφοι Τµήµα Ηλεκτρονικών Μηχανικών και Μηχανικών Υπολογιστών Πολυτεχνείο Κρήτης Γράφοι Ορισµός Αφηρηµένος τύπος δεδοµένων Υλοποίηση Αναζήτηση έντρο

Διαβάστε περισσότερα

Δέντρα (Trees) - Ιεραρχική Δομή

Δέντρα (Trees) - Ιεραρχική Δομή Δέντρα (Trees) - Ιεραρχική Δομή Εφαρμογές Δομή Οργάνωση Αρχείων Οργανογράμματα Ορισμός (αναδρομικός ορισμός): Ένα δέντρο είναι ένα πεπερασμένο σύνολο κόμβων το οποίο είτε είναι κενό είτε μη κενό σύνολο

Διαβάστε περισσότερα

Ουρές (Queues) FIFO A B C. Διαγραφή. Εισαγωγή. εµπρός. πίσω. πίσω. πίσω

Ουρές (Queues) FIFO A B C. Διαγραφή. Εισαγωγή. εµπρός. πίσω. πίσω. πίσω εµπρός Ουρές (Queues) A B C FIFO εµπρός πίσω B C Διαγραφή εµπρός πίσω B C D E Εισαγωγή πίσω Ορισµός Η ουρά είναι µια γραµµική λίστα στην οποία η διαγραφή ενός στοιχείου γίνεται στο ένα άκρο το οποίο καλείται

Διαβάστε περισσότερα

Tύπος δεδοµένων (data type) µιας µεταβλητής (σε µια γλώσσα προγραµµατισµού) είναι το σύνολο των τιµών που µπορεί να πάρει η µεταβλητή.

Tύπος δεδοµένων (data type) µιας µεταβλητής (σε µια γλώσσα προγραµµατισµού) είναι το σύνολο των τιµών που µπορεί να πάρει η µεταβλητή. Tύπος δεδοµένων (data type) µιας µεταβλητής (σε µια γλώσσα προγραµµατισµού) είναι το σύνολο των τιµών που µπορεί να πάρει η µεταβλητή. Αφηρηµένος τύπος δεδοµένων (abstract data type): είναι ένα θεωρητικό

Διαβάστε περισσότερα

Υλοποιήσεις,Δοκιμές και Εφαρμογές Βασικών Αφηρημένων Τύπων Δεδομένων στη C για εκπαιδευτική χρήση 1. Ο ΑΤΔ ΓΡΑΦΗΜΑ

Υλοποιήσεις,Δοκιμές και Εφαρμογές Βασικών Αφηρημένων Τύπων Δεδομένων στη C για εκπαιδευτική χρήση 1. Ο ΑΤΔ ΓΡΑΦΗΜΑ 1.1 Εισαγωγή 1. Ο ΑΤΔ ΓΡΑΦΗΜΑ Σε προηγούμενα κεφάλαια είδαμε γραμμικές δομές δεδομένων (στοίβα, ουρά, λίστα), στις οποίες κάθε στοιχείο μπορεί να έχει το πολύ ένα επόμενο και το πολύ ένα προηγούμενο, αλλά

Διαβάστε περισσότερα

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

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

Διαβάστε περισσότερα

Δυαδικά Δέντρα Αναζήτησης (Binary Search Trees) Ορισμός : Ένα δυαδικό δέντρο αναζήτησης t είναι ένα δυαδικό δέντρο, το οποίο είτε είναι κενό είτε:

Δυαδικά Δέντρα Αναζήτησης (Binary Search Trees) Ορισμός : Ένα δυαδικό δέντρο αναζήτησης t είναι ένα δυαδικό δέντρο, το οποίο είτε είναι κενό είτε: Δυαδικά Δέντρα Αναζήτησης (Binary Search Trees) Ορισμός : Ένα δυαδικό δέντρο αναζήτησης t είναι ένα δυαδικό δέντρο, το οποίο είτε είναι κενό είτε: (i) όλα τα περιεχόμενα στο αριστερό υποδέντρο του t είναι

Διαβάστε περισσότερα

ΟιβασικέςπράξειςπουορίζουντονΑΤΔ δυαδικό δέντρο αναζήτησης είναι οι ακόλουθες:

ΟιβασικέςπράξειςπουορίζουντονΑΤΔ δυαδικό δέντρο αναζήτησης είναι οι ακόλουθες: Δυαδικά Δέντρα Αναζήτησης (Binary Search Trees) Ορισμός : Ένα δυαδικό δέντρο αναζήτησης t είναι ένα δυαδικό δέντρο, το οποίο είτε είναι κενό είτε: (i) όλα τα περιεχόμενα στο αριστερό υποδέντρο του t είναι

Διαβάστε περισσότερα

Οι βασικές πράξεις που ορίζουν τον ΑΤ δυαδικό δέντρο αναζήτησης είναι οι ακόλουθες:

Οι βασικές πράξεις που ορίζουν τον ΑΤ δυαδικό δέντρο αναζήτησης είναι οι ακόλουθες: υαδικά έντρα Αναζήτησης (Binary Search Trees) Ορισµός : Ένα δυαδικό δέντρο αναζήτησης t είναι ένα δυαδικό δέντρο, το οποίο είτε είναι κενό είτε: (i) όλα τα περιεχόµενα στο αριστερό υποδέντρο του t είναι

Διαβάστε περισσότερα

Επισκόπηση Μαθήματος. Γραμμικές Δομές Δεδομένων. ΑΤΔ Ουρά Εναλλακτικοί Σχεδιασμοί Προγραμματισμός με Ενότητες Interface.h Implementation.

Επισκόπηση Μαθήματος. Γραμμικές Δομές Δεδομένων. ΑΤΔ Ουρά Εναλλακτικοί Σχεδιασμοί Προγραμματισμός με Ενότητες Interface.h Implementation. Γραμμικές Δομές Δεδομένων Επισκόπηση Μαθήματος Συλλογή δεδομένων στη σειρά (ολική διάταξη). Προσθέτουμε δεδομένα στη Δομή (μεγαλώνει) ή αφαιρούμε δεδομένα (μικραίνει) Αν περιορίσουμε τις πράξεις Στην Αρχή

Διαβάστε περισσότερα

Γραμμικές Δομές Δεδομένων

Γραμμικές Δομές Δεδομένων Γραμμικές Δομές Δεδομένων Συλλογή δεδομένων στη σειρά (ολική διάταξη). Προσθέτουμε δεδομένα στη Δομή (μεγαλώνει) ή αφαιρούμε δεδομένα (μικραίνει) Αν περιορίσουμε τις πράξεις Στην Αρχή μόνο Στοίβα (stack)

Διαβάστε περισσότερα

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

Δομές Δεδομένων και Αλγόριθμοι Δομές Δεδομένων και Αλγόριθμοι Χρήστος Γκόγκος ΤΕΙ Ηπείρου Χειμερινό Εξάμηνο 2014-2015 Παρουσίαση 18 Dijkstra s Shortest Path Algorithm 1 / 12 Ο αλγόριθμος εύρεσης της συντομότερης διαδρομής του Dijkstra

Διαβάστε περισσότερα

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

Διάλεξη 17: Δυαδικά Δέντρα. Διδάσκων: Κωνσταντίνος Κώστα Διαφάνειες: Δημήτρης Ζεϊναλιπούρ Διάλεξη 7: Δυαδικά Δέντρα Στην ενότητα αυτή θα μελετηθούν τα εξής επιμέρους θέματα: Δυαδικά Δένδρα Δυαδικά Δένδρα Αναζήτησης Πράξεις Εισαγωγής, Εύρεσης Στοιχείου, Διαγραφής Μικρότερου Στοιχείου Διδάσκων:

Διαβάστε περισσότερα

ΣΤΟΙΒΕΣ (stacks) Σχήµα: Λειτουργία Στοίβας

ΣΤΟΙΒΕΣ (stacks) Σχήµα: Λειτουργία Στοίβας ΣΤΟΙΒΕΣ (stacks) Η στοίβα είναι µια συλλογή δεδοµένων µε γραµµική διάταξη στην οποία όλες οι εισαγωγές και οι διαγραφές γίνονται στο ένα άκρο που λέγεται κορυφή (top) της στοίβας Σχήµα: Λειτουργία Στοίβας

Διαβάστε περισσότερα

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

Δομές Δεδομένων. Ενότητα 1: Εισαγωγή-Υλοποίηση του ΑΤΔ Σύνολο με Πίνακα. Καθηγήτρια Μαρία Σατρατζέμη. Τμήμα Εφαρμοσμένης Πληροφορικής. Ενότητα 1: Εισαγωγή-Υλοποίηση του ΑΤΔ Σύνολο με Πίνακα Καθηγήτρια Μαρία Σατρατζέμη Άδειες Χρήσης Το παρόν εκπαιδευτικό υλικό υπόκειται σε άδειες χρήσης Creative Commons. Για εκπαιδευτικό υλικό, όπως εικόνες,

Διαβάστε περισσότερα

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

Διάλεξη 22: Δυαδικά Δέντρα. Διδάσκων: Παναγιώτης Ανδρέου Διάλεξη 22: Δυαδικά Δέντρα Στην ενότητα αυτή θα μελετηθούν τα εξής επιμέρους θέματα: - Δυαδικά Δένδρα - Δυαδικά Δένδρα Αναζήτησης - Πράξεις Εισαγωγής, Εύρεσης Στοιχείου, Διαγραφής Μικρότερου Στοιχείου

Διαβάστε περισσότερα

Δομές Δεδομένων και Τεχνικές Προγραμματισμού Ενότητα 3: ΑΤΔ Ουρά. Ιωάννης Κοτρώνης Σχολή Θετικών Επιστημών Τμήμα Πληροφορικής και Τηλεπικοινωνιών

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

Διαβάστε περισσότερα

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

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

Διαβάστε περισσότερα

ΕΠΛ232: Εργαστήριο 2

ΕΠΛ232: Εργαστήριο 2 ΕΠΛ232: Εργαστήριο 2 Παράδειγμα σε Στοίβες 1 Υπολογισμός Αριθμητικών Παραστάσεων - Πολωνικός Συμβολισμός A + (B * C) A + (BC * ) A(BC *) + ABC * + Ενδοθεματική μορφή Μεταθεματική μορφή Οι κανόνες που διέπουν

Διαβάστε περισσότερα

1 Το πρόβλημα της συντομότερης διαδρομής

1 Το πρόβλημα της συντομότερης διαδρομής ΤΕΧΝΟΛΟΓΙΚΟ ΕΚΠΑΙΔΕΥΤΙΚΟ ΙΔΡΥΜΑ ΛΑΜΙΑΣ ΤΜΗΜΑ ΠΛΗΡΟΦΟΡΙΚΗΣ ΚΑΙ ΤΕΧΝΟΛΟΓΙΑΣ ΥΠΟΛΟΓΙΣΤΩΝ ΣΧΕΔΙΑΣΜΟΣ ΚΑΙ ΑΝΑΛΥΣΗ ΑΛΓΟΡΙΘΜΩΝ ΑΚΑΔΗΜΑΪΚΟ ΕΤΟΣ 00 Ιστοσελίδα μαθήματος: http://eclass.teilam.gr/di88 6ο ΕΡΓΑΣΤΗΡΙΟ

Διαβάστε περισσότερα

ΔΙΑΣΧΙΣΗ ΓΡΑΦΗΜΑΤΩΝ 1

ΔΙΑΣΧΙΣΗ ΓΡΑΦΗΜΑΤΩΝ 1 ΔΙΑΣΧΙΣΗ ΓΡΑΦΗΜΑΤΩΝ 1 Θέματα μελέτης Πρόβλημα αναζήτησης σε γραφήματα Αναζήτηση κατά βάθος (Depth-first search DFS) Αναζήτηση κατά πλάτος (Breadth-first search BFS) 2 Γράφημα (graph) Αναπαράσταση συνόλου

Διαβάστε περισσότερα

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

ΕΛΛΗΝΙΚΟ ΑΝΟΙΚΤΟ ΠΑΝΕΠΙΣΤΗΜΙΟ ΟΔΗΓΙΕΣ: ΘΕΜΑΤΙΚΗ ΕΝΟΤΗΤΑ ΕΙΣΑΓΩΓΗ ΣΤΗΝ ΠΛΗΡΟΦΟΡΙΚΗ - ΠΛΗ10 ΤΕΛΙΚΕΣ ΕΞΕΤΑΣΕΙΣ - 14 ΙΟΥΝΙΟΥ 2015 Τα θέματα που έχετε στα χέρια σας είναι σε τρεις (3) σελίδες. Επιβεβαιώστε το και αν λείπει κάποια σελίδα

Διαβάστε περισσότερα

Διδάσκων: Κωνσταντίνος Κώστα

Διδάσκων: Κωνσταντίνος Κώστα Διάλεξη Ε4: Επανάληψη Στην ενότητα αυτή θα μελετηθούν τα εξής επιμέρους θέματα: Εισαγωγή σε δενδρικές δομές δεδομένων, Δυαδικά Δένδρα Αναζήτησης Ισοζυγισμένα Δένδρα & 2-3 Δένδρα Διδάσκων: Κωνσταντίνος

Διαβάστε περισσότερα

ρίζα E F G H I J επίπεδο 1

ρίζα E F G H I J επίπεδο 1 Δέντρα (Trees) Ορισµός: Ενα δέντρο είναι ένα πεπερασµένο µη κενό σύνολο κόµβων τέτοιο ώστε: 1.Yπάρχει ένας µοναδικός κόµβος, που καλείται ρίζα, ο οποίος δεν έχει προηγούµενο. 2.Οι υπόλοιποι κόµβοι χωρίζονται

Διαβάστε περισσότερα

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

Διδάσκων: Παναγιώτης Ανδρέου Διάλεξη 12: Δέντρα ΙΙ -Δυαδικά Δέντρα Στην ενότητα αυτή θα μελετηθούν τα εξής επιμέρους θέματα: - Δυαδικά Δένδρα - Δυαδικά Δένδρα Αναζήτησης(ΔΔΑ) - Εύρεση Τυχαίου, Μέγιστου, Μικρότερου στοιχείου - Εισαγωγή

Διαβάστε περισσότερα

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

Κατ οίκον Εργασία 5 Σκελετοί Λύσεων Κατ οίκον Εργασία 5 Σκελετοί Λύσεων Άσκηση 1 Χρησιμοποιούμε τις δομές: struct hashtable { struct node array[maxsize]; int maxsize; int size; struct node{ int data; int status; Στο πεδίο status σημειώνουμε

Διαβάστε περισσότερα

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

Διδάσκων: Κωνσταντίνος Κώστα Διαφάνειες: Δημήτρης Ζεϊναλιπούρ Διάλεξη 9: Εισαγωγή στους Γράφους Στην ενότητα αυτή θα μελετηθούν τα εξής επιμέρους θέματα: Γράφοι - ορισμοί και υλοποίηση Διάσχιση Γράφων Διδάσκων: Κωνσταντίνος Κώστα Διαφάνειες: Δημήτρης Ζεϊναλιπούρ

Διαβάστε περισσότερα

2 η Υλοποίηση του ΑΤΔ συνδεδεμένη λίστα με πίνακα Κόμβοι από δεδομένα και θέσεις πίνακα ????

2 η Υλοποίηση του ΑΤΔ συνδεδεμένη λίστα με πίνακα Κόμβοι από δεδομένα και θέσεις πίνακα ???? η Υλοποίηση του ΑΤΔ συνδεδεμένη λίστα με πίνακα Κόμβοι από δεδομένα και θέσεις πίνακα θέση (index) dedomena epomenos lista = 0 1 3 Ελένη Σπύρος Βασίλης -1 1 Στη συνέχεια θα πρέπει να γνωρίζουμε την οργάνωση

Διαβάστε περισσότερα

Προγραμματισμός Ι (ΗΥ120)

Προγραμματισμός Ι (ΗΥ120) Προγραμματισμός Ι (ΗΥ120) Διάλεξη 20: Δυαδικό Δέντρο Αναζήτησης Δυαδικό δέντρο Κάθε κόμβος «γονέας» περιέχει δύο δείκτες που δείχνουν σε δύο κόμβους «παιδιά» του ιδίου τύπου. Αν οι δείκτες προς αυτούς

Διαβάστε περισσότερα

u v 4 w G 2 G 1 u v w x y z 4

u v 4 w G 2 G 1 u v w x y z 4 Διάλεξη :.0.06 Θεωρία Γραφημάτων Γραφέας: Σ. Κ. Διδάσκων: Σταύρος Κολλιόπουλος. Εισαγωγικοί ορισμοί Ορισμός. Γράφημα G καλείται ένα ζεύγος G = (V, E) όπου V είναι το σύνολο των κορυφών (ή κόμβων) και E

Διαβάστε περισσότερα

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

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

Διαβάστε περισσότερα

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

Δομές Δεδομένων. Ενότητα 10: Πλήρη Δυαδικά Δέντρα, Μέγιστα/Ελάχιστα Δέντρα & Εισαγωγή στο Σωρό- Ο ΑΤΔ Μέγιστος Σωρός. Καθηγήτρια Μαρία Σατρατζέμη Ενότητα 10: Πλήρη Δυαδικά Δέντρα, Μέγιστα/Ελάχιστα Δέντρα & Εισαγωγή στο Σωρό- Ο ΑΤΔ Μέγιστος Σωρός Καθηγήτρια Μαρία Σατρατζέμη Άδειες Χρήσης Το παρόν εκπαιδευτικό υλικό υπόκειται σε άδειες χρήσης Creative

Διαβάστε περισσότερα

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

Αλγόριθμοι και Δομές Δεδομένων (IΙ) (γράφοι και δένδρα) Ιόνιο Πανεπιστήμιο Τμήμα Πληροφορικής Εισαγωγή στην Επιστήμη των Υπολογιστών 2016-17 Αλγόριθμοι και Δομές Δεδομένων (IΙ) (γράφοι και δένδρα) http://mixstef.github.io/courses/csintro/ Μ.Στεφανιδάκης Αφηρημένες

Διαβάστε περισσότερα

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

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

Διαβάστε περισσότερα

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

ΤΕΙ ΛΑΜΙΑΣ ΤΜΗΜΑ ΠΛΗΡΟΦΟΡΙΚΗΣ ΚΑΙ ΤΕΧΝΟΛΟΓΙΑ ΥΠΟΛΟΓΙΣΤΩΝ ÌïëëÜ Ì. Á μýô Á.Ì. : 5 moll@moll.r ΤΕΙ ΛΑΜΙΑΣ ΤΜΗΜΑ ΠΛΗΡΟΦΟΡΙΚΗΣ ΚΑΙ ΤΕΧΝΟΛΟΓΙΑ ΥΠΟΛΟΓΙΣΤΩΝ ΜΑΘΗΜΑ : ΕΙΣΑΓΩΓΗ ΣΤΟ ΔΙΑΔΙΚΤΥΟ (ΕΡΓΑΣΤΗΡΙΟ) Ε ΕΞΑΜΗΝΟ ΕΙΣΗΓΗΤΕΣ: Χαϊδόγιαννος Χαράλαμπος ΕΡΓΑΣΤΗΡΙΑΚΗ ΑΣΚΗΣΗ

Διαβάστε περισσότερα

AVL δέντρα. h L h R. G.M. Adelson_Velkii και E.M. Landis 1962

AVL δέντρα. h L h R. G.M. Adelson_Velkii και E.M. Landis 1962 AVL δέντρα L - R 1 L R G.M. AdelsonVelkii και E.M. Landis 1962 AVL Δέντρα Μη AVL Δέντρα Εισαγωγή κόμβου 4, 6 : 4 12 : 6 4 6 Αριστερή στροφή 6 4 12 12 8, 14 : 6 4 12 8 14 7 : 4 6 12 6 4 8 6 8 12 7 8 14

Διαβάστε περισσότερα

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

Διάλεξη 12: Λίστες Υλοποίηση & Εφαρμογές. Διδάσκων: Παναγιώτης Ανδρέου Διάλεξη 12: Λίστες Υλοποίηση & Εφαρμογές Στην ενότητα αυτή θα μελετηθούν τα εξής επιμέρους θέματα: -Ευθύγραμμες Απλά Συνδεδεμένες Λίστες (εύρεση, εισαγωγή, διαγραφή) - Σύγκριση Συνδεδεμένων Λιστών με Πίνακες

Διαβάστε περισσότερα

Γράφοι. Ορολογία. Ορισµός: G = (V, E) όπου. Ορολογία (συνέχεια) γράφος ή γράφηµα (graph) V:ένα σύνολο E:µια διµελής σχέση στο V

Γράφοι. Ορολογία. Ορισµός: G = (V, E) όπου. Ορολογία (συνέχεια) γράφος ή γράφηµα (graph) V:ένα σύνολο E:µια διµελής σχέση στο V Γράφοι Ορολογία γράφος ή γράφηµα (graph) Ορισµός: G = (V, E) όπου V:ένα σύνολο E:µια διµελής σχέση στο V Ορολογία (συνέχεια) κάθε v V ονοµάζεται κορυφή (vertex) ή κόµβος (node) κάθε (v 1, v 2 ) Ε ονοµάζεται

Διαβάστε περισσότερα

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

Κατ οίκον Εργασία 5 Σκελετοί Λύσεων Κατ οίκον Εργασία 5 Σκελετοί Λύσεων Άσκηση 1 (α) Ο αλγόριθµος χρησιµοποιεί τη διαδικασία DFS(v) η οποία, ως γνωστό, επισκέπτεται όλους τους κόµβους που είναι συνδεδεµένοι µε τον κόµβο v. Για να µετρήσουµε

Διαβάστε περισσότερα

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

ΕΠΛ 231 Δοµές Δεδοµένων και Αλγόριθµοι 11-1 Γράφοι Στην ενότητα αυτή θα µελετηθούν τα εξής επιµέρους θέµατα: Γράφοι - ορισµοί και υλοποίηση Διάσχιση Γράφων Τοπολογική Ταξινόµηση ΕΠΛ 23 Δοµές Δεδοµένων και Αλγόριθµοι - Γράφοι Η πιο γενική µορφή δοµής

Διαβάστε περισσότερα

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

Πανεπιστήμιο Πειραιώς Σχολή Τεχνολογιών Πληροφορικής και Επικοινωνιών Τμήμα Ψηφιακών Συστημάτων ομές εδομένων Πανεπιστήμιο Πειραιώς Σχολή Τεχνολογιών Πληροφορικής και Επικοινωνιών Τμήμα Ψηφιακών Συστημάτων 6. Δυαδικά Δέντρα 2 ομές εδομένων 4 5 Χρήστος ουλκερίδης Τμήμα Ψηφιακών Συστημάτων 18/11/2016 Εισαγωγή Τα

Διαβάστε περισσότερα

1. ΕΙΣΑΓΩΓΗ-ΓΕΝΙΚΑ ΠΕΡΙ ΑΦΗΡΗΜΕΝΩΝ ΤΥΠΩΝ ΔΕΔΟΜΕΝΩΝ

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

Διαβάστε περισσότερα

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

Διάλεξη 12: Δέντρα ΙΙ Δυαδικά Δέντρα Διάλεξη 12: Δέντρα ΙΙ Δυαδικά Δέντρα Στην ενότητα αυτή θα μελετηθούν τα εξής επιμέρους θέματα: Δυαδικά Δένδρα Δυαδικά Δένδρα Αναζήτησης (ΔΔΑ) Εύρεση Τυχαίου, Μέγιστου, Μικρότερου στοιχείου Εισαγωγή στοιχείου

Διαβάστε περισσότερα

Αναζήτηση Κατά Πλάτος

Αναζήτηση Κατά Πλάτος Αναζήτηση Κατά Πλάτος ημήτρης Φωτάκης Σχολή Ηλεκτρολόγων Μηχανικών και Μηχανικών Υπολογιστών Εθνικό Μετσόβιο Πολυτεχνείο Γραφήματα Μοντελοποίηση πολλών σημαντικών προβλημάτων (π.χ. δίκτυα συνεκτικότητα,

Διαβάστε περισσότερα

1 Διάσχιση κατευθυνόμενων γραφημάτων

1 Διάσχιση κατευθυνόμενων γραφημάτων ΤΕΧΝΟΛΟΓΙΚΟ ΕΚΠΑΙΔΕΥΤΙΚΟ ΙΔΡΥΜΑ ΛΑΜΙΑΣ ΤΜΗΜΑ ΠΛΗΡΟΦΟΡΙΚΗΣ ΚΑΙ ΤΕΧΝΟΛΟΓΙΑΣ ΥΠΟΛΟΓΙΣΤΩΝ ΣΧΕΔΙΑΣΜΟΣ ΚΑΙ ΑΝΑΛΥΣΗ ΑΛΓΟΡΙΘΜΩΝ ΑΚΑΔΗΜΑΪΚΟ ΕΤΟΣ 2010 11 Ιστοσελίδα μαθήματος: http://eclass.teilam.gr/di288 5ο ΕΡΓΑΣΤΗΡΙΟ

Διαβάστε περισσότερα

Αναζήτηση Κατά Πλάτος

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

Διαβάστε περισσότερα

Αλγόριθµοι και Πολυπλοκότητα

Αλγόριθµοι και Πολυπλοκότητα Αλγόριθµοι και Πολυπλοκότητα Ν. Μ. Μισυρλής Τµήµα Πληροφορικής και Τηλεπικοινωνιών, Πανεπιστήµιο Αθηνών Καθηγητής: Ν. Μ. Μισυρλής () Αλγόριθµοι και Πολυπλοκότητα 26 Ιουνίου 201 1 / Απληστοι (Greedy) Αλγόριθµοι

Διαβάστε περισσότερα

Αλγόριθµοι και Πολυπλοκότητα

Αλγόριθµοι και Πολυπλοκότητα Αλγόριθµοι και Πολυπλοκότητα Ν. Μ. Μισυρλής Τµήµα Πληροφορικής και Τηλεπικοινωνιών, Πανεπιστήµιο Αθηνών Καθηγητής: Ν. Μ. Μισυρλής () Αλγόριθµοι και Πολυπλοκότητα Μαΐου 201 1 / Απληστοι (Greedy) Αλγόριθµοι

Διαβάστε περισσότερα

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

ΠΑΝΕΠΙΣΤΗΜΙΟ ΚΥΠΡΟΥ ΕΠΛ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΣ ΜΕΘΟΔΩΝ ΕΠΙΛΥΣΗΣ ΠΡΟΒΛΗΜΑΤΩΝ ΠΑΝΕΠΙΣΤΗΜΙΟ ΚΥΠΡΟΥ ΕΠΛ 032 2 ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΣ ΜΕΘΟΔΩΝ ΕΠΙΛΥΣΗΣ ΠΡΟΒΛΗΜΑΤΩΝ Ενδιάμεση Εξέταση Ημερομηνία:08/03/10 Διάρκεια: 13:30 15:00 Διδάσκων: Παύλος Αντωνίου Ονοματεπώνυμο: Αριθμός Ταυτότητας: Η εξέταση

Διαβάστε περισσότερα

Βασικές Δοµές Δεδοµένων. Σύντοµη επανάληψη (ΕΠΛ 035).

Βασικές Δοµές Δεδοµένων. Σύντοµη επανάληψη (ΕΠΛ 035). Βασικές Δοµές Δεδοµένων Σύντοµη επανάληψη (ΕΠΛ 035). Περίληψη Γραµµικές Δοµές Δεδοµένων Πίνακες Λίστες Στοίβες Ουρές Γράφοι Δέντρα Γραµµικές Δοµές Πίνακας (array) A[0] A[1] A[2] A[ ] A[n-1] Προκαθορισµένη

Διαβάστε περισσότερα

Εισαγωγή στους Αλγόριθμους

Εισαγωγή στους Αλγόριθμους Εισαγωγή στους Αλγόριθμους Εύη Παπαϊωάννου Σχολή Οργάνωσης και Διοίκησης Επιχειρήσεων Τμήμα Διαχείρισης Πολιτισμικού Περιβάλλοντος και Νέων Τεχνολογιών Σκοποί ενότητας Παρουσίαση και μελέτη αλγορίθμων

Διαβάστε περισσότερα

Σχεδιαση Αλγοριθμων -Τμημα Πληροφορικης ΑΠΘ - Κεφαλαιο 9ο

Σχεδιαση Αλγοριθμων -Τμημα Πληροφορικης ΑΠΘ - Κεφαλαιο 9ο Σχεδίαση Αλγορίθμων Άπληστοι Αλγόριθμοι http://delab.csd.auth.gr/~gounaris/courses/ad 1 Άπληστοι αλγόριθμοι Προβλήματα βελτιστοποίησης ηςλύνονται με μια σειρά επιλογών που είναι: εφικτές τοπικά βέλτιστες

Διαβάστε περισσότερα

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

Εργαστήριο 4: Υλοποίηση Αφηρημένου Τύπου Δεδομένων: Ταξινομημένη Λίστα Εργαστήριο 4: Υλοποίηση Αφηρημένου Τύπου Δεδομένων: Ταξινομημένη Λίστα Στην ενότητα αυτή θα μελετηθούν τα εξής επιμέρους θέματα: -Λίστες -Υλοποίηση ταξινομημένης λίστας με δυναμική δέσμευση μνήμης ΕΠΛ035

Διαβάστε περισσότερα

Δομές Δεδομένων. Ενότητα 7: Άλλες παραλλαγές Συνδεδεμένων Λιστών-Παράσταση Αραιού Πολυωνύμου με Συνδεδεμένη Λίστα. Καθηγήτρια Μαρία Σατρατζέμη

Δομές Δεδομένων. Ενότητα 7: Άλλες παραλλαγές Συνδεδεμένων Λιστών-Παράσταση Αραιού Πολυωνύμου με Συνδεδεμένη Λίστα. Καθηγήτρια Μαρία Σατρατζέμη Ενότητα 7: Άλλες παραλλαγές Συνδεδεμένων Λιστών-Παράσταση Αραιού Πολυωνύμου με Συνδεδεμένη Λίστα Καθηγήτρια Μαρία Σατρατζέμη Άδειες Χρήσης Το παρόν εκπαιδευτικό υλικό υπόκειται σε άδειες χρήσης Creative

Διαβάστε περισσότερα

Δομές Δεδομένων. Καθηγήτρια Μαρία Σατρατζέμη. Τμήμα Εφαρμοσμένης Πληροφορικής. Δομές Δεδομένων. Τμήμα Εφαρμοσμένης Πληροφορικής

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

Διαβάστε περισσότερα

Α. unsigned int Β. double. Γ. int. unsigned char x = 1; x = x + x ; x = x * x ; x = x ^ x ; printf("%u\n", x); Β. unsigned char

Α. unsigned int Β. double. Γ. int. unsigned char x = 1; x = x + x ; x = x * x ; x = x ^ x ; printf(%u\n, x); Β. unsigned char ΕΙΣΑΓΩΓΗ ΣΤΟΝ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟ Εξετάσεις Β Περιόδου 2015 (8/9/2015) ΟΝΟΜΑΤΕΠΩΝΥΜΟ:................................................................................ Α.Μ.:...............................................

Διαβάστε περισσότερα

Αλγόριθμοι Ταξινόμησης Μέρος 1

Αλγόριθμοι Ταξινόμησης Μέρος 1 Αλγόριθμοι Ταξινόμησης Μέρος 1 Μανόλης Κουμπαράκης 1 Το Πρόβλημα της Ταξινόμησης Το πρόβλημα της ταξινόμησης (sorting) μιας ακολουθίας στοιχείων με κλειδιά ενός γνωστού τύπου (π.χ., τους ακέραιους ή τις

Διαβάστε περισσότερα

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

Διδάσκων: Κωνσταντίνος Κώστα Διαφάνειες: Δημήτρης Ζεϊναλιπούρ ιάλεξη : λάχιστα εννητορικά ένδρα Αλγόριθμος Prim Στην ενότητα αυτή θα μελετηθούν τα εξής επιμέρους θέματα: λάχιστα εννητορικά ένδρα () Minimum Spanning Trees Ο αλγόριθμος του Prim για εύρεση σε γράφους

Διαβάστε περισσότερα

ΣΥΜΒΟΛΟΣΕΙΡΕΣ (Strings) Ο ΑΤΔ Συµβολοσειρά Μία συµβολοσειρά είναι µία ακολουθία χαρακτήρων. Bασικές πράξεις : 1. Δηµιουργία. 2. Μήκος. 3.

ΣΥΜΒΟΛΟΣΕΙΡΕΣ (Strings) Ο ΑΤΔ Συµβολοσειρά Μία συµβολοσειρά είναι µία ακολουθία χαρακτήρων. Bασικές πράξεις : 1. Δηµιουργία. 2. Μήκος. 3. ΣΥΜΒΟΛΟΣΕΙΡΕΣ (Strings) Ο ΑΤΔ Συµβολοσειρά Μία συµβολοσειρά είναι µία ακολουθία χαρακτήρων Bασικές πράξεις : 1. Δηµιουργία 2. Μήκος 3. Ανάκτηση 4. Προσάρτηση 5. Διαγραφή 6. Αντιγραφή 7. Συνένωση 8. Αναζήτηση

Διαβάστε περισσότερα

Αναζήτηση Κατά Πλάτος

Αναζήτηση Κατά Πλάτος Αναζήτηση Κατά Πλάτος ιδάσκοντες: Σ. Ζάχος,. Φωτάκης Επιμέλεια διαφανειών:. Φωτάκης Σχολή Ηλεκτρολόγων Μηχανικών και Μηχανικών Υπολογιστών Εθνικό Μετσόβιο Πολυτεχνείο Άδεια Χρήσης Το παρόν εκπαιδευτικό

Διαβάστε περισσότερα

Γέφυρες σε Δίκτυα. Μας δίνεται ένα δίκτυο (κατευθυνόμενο γράφημα) αφετηριακός κόμβος. Γέφυρα του (με αφετηρία τον ) :

Γέφυρες σε Δίκτυα. Μας δίνεται ένα δίκτυο (κατευθυνόμενο γράφημα) αφετηριακός κόμβος. Γέφυρα του (με αφετηρία τον ) : Μας δίνεται ένα δίκτυο (κατευθυνόμενο γράφημα) αφετηριακός κόμβος και Γέφυρα του (με αφετηρία τον ) : Ακμή που περιέχεται σε κάθε μονοπάτι από το στο s a b c d e f g h i j k l Μας δίνεται ένα δίκτυο (κατευθυνόμενο

Διαβάστε περισσότερα

Γράφημα. Συνδυαστικό αντικείμενο που αποτελείται από 2 σύνολα: Σύνολο κορυφών (vertex set) Σύνολο ακμών (edge set) 4 5 πλήθος κορυφών πλήθος ακμών

Γράφημα. Συνδυαστικό αντικείμενο που αποτελείται από 2 σύνολα: Σύνολο κορυφών (vertex set) Σύνολο ακμών (edge set) 4 5 πλήθος κορυφών πλήθος ακμών Γράφημα Συνδυαστικό αντικείμενο που αποτελείται από 2 σύνολα: Σύνολο κορυφών (vertex set) Σύνολο ακμών (edge set) 1 2 3 4 5 πλήθος κορυφών πλήθος ακμών Γράφημα Συνδυαστικό αντικείμενο που αποτελείται από

Διαβάστε περισσότερα

ΣΤΟΙΒΑ ΧΑΡΑΚΤΗΡΙΣΤΙΚΗ ΙΔΙΟΤΗΤΑ ΤΗΣ ΣΤΟΙΒΑΣ. Το τελευταίο στοιχείο που εισήχθη θα εξαχθεί πρώτο. Άλλο όνομα L I F O (Last In First Out)

ΣΤΟΙΒΑ ΧΑΡΑΚΤΗΡΙΣΤΙΚΗ ΙΔΙΟΤΗΤΑ ΤΗΣ ΣΤΟΙΒΑΣ. Το τελευταίο στοιχείο που εισήχθη θα εξαχθεί πρώτο. Άλλο όνομα L I F O (Last In First Out) ΣΤΟΙΒΑ ΧΑΡΑΚΤΗΡΙΣΤΙΚΗ ΙΔΙΟΤΗΤΑ ΤΗΣ ΣΤΟΙΒΑΣ Το τελευταίο στοιχείο που εισήχθη θα εξαχθεί πρώτο. Άλλο όνομα L I F O (Last In First Out) Χρήσεις Στοίβας Καθημερινή Ζωή (όχι πάρα πολλές) Δίσκοι Τραπεζαρίας

Διαβάστε περισσότερα

ΣΤΟΙΒΑ ΧΑΡΑΚΤΗΡΙΣΤΙΚΗ ΙΔΙΟΤΗΤΑ ΤΗΣ ΣΤΟΙΒΑΣ. Το τελευταίο στοιχείο που εισήχθη θα εξαχθεί πρώτο. Άλλο όνομα L I F O (Last In First Out)

ΣΤΟΙΒΑ ΧΑΡΑΚΤΗΡΙΣΤΙΚΗ ΙΔΙΟΤΗΤΑ ΤΗΣ ΣΤΟΙΒΑΣ. Το τελευταίο στοιχείο που εισήχθη θα εξαχθεί πρώτο. Άλλο όνομα L I F O (Last In First Out) ΣΤΟΙΒΑ ΧΑΡΑΚΤΗΡΙΣΤΙΚΗ ΙΔΙΟΤΗΤΑ ΤΗΣ ΣΤΟΙΒΑΣ Το τελευταίο στοιχείο που εισήχθη θα εξαχθεί πρώτο. Άλλο όνομα L I F O (Last In First Out) Χρήσεις Στοίβας Καθημερινή Ζωή (όχι πάρα πολλές) Δίσκοι Τραπεζαρίας

Διαβάστε περισσότερα

Αλγόριθμοι Γραφημάτων

Αλγόριθμοι Γραφημάτων Αλγόριθμοι Γραφημάτων. Γραφήματα. Αναπαράσταση Γραφημάτων 3. Διερεύνηση σε Πρώτα σε Πλάτος (BFS) Εισαγωγή στην Ανάλυση Αλγορίθμων Μάγια Σατρατζέμη Γράφημα Ορισμός: Ένα γράφημα G είναι το διατεταγμένο ζεύγος

Διαβάστε περισσότερα

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

Κατ οίκον Εργασία 3 Σκελετοί Λύσεων Κατ οίκον Εργασία 3 Σκελετοί Λύσεων Άσκηση 1 (α) Έστω Α(n) και Κ(n) ο αριθμός των ακμών και ο αριθμός των κόμβων ενός αυστηρά δυαδικού δένδρου με n φύλλα. Θέλουμε να αποδείξουμε για κάθε n 1 την πρόταση

Διαβάστε περισσότερα

υαδικό δέντρο έντρα (Trees) -Ιεραρχική οµή

υαδικό δέντρο έντρα (Trees) -Ιεραρχική οµή έντρα (Trees) Ιεραρχική οµή Εφαρµογές οµή Οργάνωση ρχείων Οργανογράµµατα Ορισµός (αναδροµικός ορισµός): Ένα δέντρο είναι ένα πεπερασµένο σύνολο κόµβων το οποίο είτε είναι κενό είτε µη κενό σύνολο τέτοιο

Διαβάστε περισσότερα

Διακριτά Μαθηματικά ΙΙ Χρήστος Νομικός Τμήμα Μηχανικών Η/Υ και Πληροφορικής Πανεπιστήμιο Ιωαννίνων 2018 Χρήστος Νομικός ( Τμήμα Μηχανικών Η/Υ Διακριτά

Διακριτά Μαθηματικά ΙΙ Χρήστος Νομικός Τμήμα Μηχανικών Η/Υ και Πληροφορικής Πανεπιστήμιο Ιωαννίνων 2018 Χρήστος Νομικός ( Τμήμα Μηχανικών Η/Υ Διακριτά Διακριτά Μαθηματικά ΙΙ Χρήστος Νομικός Τμήμα Μηχανικών Η/Υ και Πληροφορικής Πανεπιστήμιο Ιωαννίνων 2018 Χρήστος Νομικός ( Τμήμα Μηχανικών Η/Υ Διακριτά και Πληροφορικής Μαθηματικά Πανεπιστήμιο ΙΙ Ιωαννίνων

Διαβάστε περισσότερα

Θεωρία Γραφημάτων 5η Διάλεξη

Θεωρία Γραφημάτων 5η Διάλεξη Θεωρία Γραφημάτων 5η Διάλεξη Α. Συμβώνης Εθνικό Μετσόβιο Πολυτεχνείο Σχολή Εφαρμοσμένων Μαθηματικών και Φυσικών Επιστημών Τομέας Μαθηματικών Φεβρουάριος 2017 Α. Συμβώνης (ΕΜΠ) Θεωρία Γραφημάτων 5η Διάλεξη

Διαβάστε περισσότερα

ΕΠΛ 231 οµές εδοµένων και Αλγόριθµοι Άννα Φιλίππου,

ΕΠΛ 231 οµές εδοµένων και Αλγόριθµοι Άννα Φιλίππου, Γράφοι Στην ενότητα αυτή θα µελετηθούν τα εξής επιµέρους θέµατα: Γράφοι - ορισµοί και υλοποίηση Τοπολογική Ταξινόµηση ιάσχιση Γράφων ΕΠΛ 23 οµές εδοµένων και Αλγόριθµοι Άννα Φιλίππου, 26 - Γράφοι Ηπιο

Διαβάστε περισσότερα

Εισαγωγή στην Επιστήμη των Υπολογιστών

Εισαγωγή στην Επιστήμη των Υπολογιστών Εισαγωγή στην Επιστήμη των Υπολογιστών 4 ο εξάμηνο ΣΗΜΜΥ 4 η ενότητα: Γράφοι: προβλήματα και αλγόριθμοι Επιμέλεια διαφανειών: Στάθης Ζάχος, Άρης Παγουρτζής, Δημήτρης Φωτάκης Σχολή Ηλεκτρολόγων Μηχανικών

Διαβάστε περισσότερα

Εισαγωγή στην C. Μορφή Προγράµµατος σε γλώσσα C

Εισαγωγή στην C. Μορφή Προγράµµατος σε γλώσσα C Εισαγωγή στην C Μορφή Προγράµµατος σε γλώσσα C Τµήµα Α Με την εντολή include συµπεριλαµβάνω στο πρόγραµµα τα πρότυπα των συναρτήσεων εισόδου/εξόδου της C.Το αρχείο κεφαλίδας stdio.h είναι ένας κατάλογος

Διαβάστε περισσότερα

6η Διάλεξη Διάσχιση Γράφων και Δέντρων

6η Διάλεξη Διάσχιση Γράφων και Δέντρων ΘΕΩΡΙΑ ΓΡΑΦΩΝ 6 η Διάλεξη Διάσχιση Γράφων και Δέντρων Αλγόριθμος αναζήτησης σε Βαθος Αλγόριθμος αναζήτησης κατά Πλάτος Αλγόριθμοι για Δένδρα Εύρεση ελαχίστων Γεννητορικών (Επικαλύπτοντα) Δένδρων Διάσχιση

Διαβάστε περισσότερα

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

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

Διαβάστε περισσότερα

Δένδρα. Μαθηματικά (συνδυαστικά) αντικείμενα. Έχουν κεντρικό ρόλο στην επιστήμη των υπολογιστών :

Δένδρα. Μαθηματικά (συνδυαστικά) αντικείμενα. Έχουν κεντρικό ρόλο στην επιστήμη των υπολογιστών : Δένδρα Μαθηματικά (συνδυαστικά) αντικείμενα. Έχουν κεντρικό ρόλο στην επιστήμη των υπολογιστών : Ανάλυση αλγορίθμων (π.χ. δένδρα αναδρομής) Δομές δεδομένων (π.χ. δένδρα αναζήτησης) ακμή Κατηγορίες (αύξουσα

Διαβάστε περισσότερα

Αναζήτηση Κατά Πλάτος

Αναζήτηση Κατά Πλάτος Αναζήτηση Κατά Πλάτος Επιµέλεια διαφανειών:. Φωτάκης Σχολή Ηλεκτρολόγων Μηχανικών και Μηχανικών Υπολογιστών Εθνικό Μετσόβιο Πολυτεχνείο Γραφήµατα Μοντελοποίηση πολλών σηµαντικών προβληµάτων (π.χ. δίκτυα

Διαβάστε περισσότερα

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

ΟΙΚΟΝΟΜΙΚΟ ΠΑΝΕΠΙΣΤΗΜΙΟ ΑΘΗΝΩΝ ΤΜΗΜΑ ΠΛΗΡΟΦΟΡΙΚΗΣ ΦΡΟΝΤΙΣΤΗΡΙΟ ΑΛΓΟΡΙΘΜΩΝ ΒΟΗΘΟΣ: ΒΑΓΓΕΛΗΣ ΔΟΥΡΟΣ 1 ΟΙΚΟΝΟΜΙΚΟ ΠΑΝΕΠΙΣΤΗΜΙΟ ΑΘΗΝΩΝ ΤΜΗΜΑ ΠΛΗΡΟΦΟΡΙΚΗΣ ΦΡΟΝΤΙΣΤΗΡΙΟ ΑΛΓΟΡΙΘΜΩΝ ΒΟΗΘΟΣ: ΒΑΓΓΕΛΗΣ ΔΟΥΡΟΣ Φροντιστήριο #2: Πολυωνυμικοί Αλγόριθμοι, Εισαγωγή στα Γραφήματα, Αναζήτηση κατά Βάθος, Τοπολογική Ταξινόμηση

Διαβάστε περισσότερα

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

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

Διαβάστε περισσότερα

Δρ. Πέτρος Παναγή B123

Δρ. Πέτρος Παναγή B123 Δρ. Πέτρος Παναγή petrosp@cs.ucy.ac.cy B123 1 ΣΥΜΒΟΛΟΣΕΙΡΕΣ (Strings) Ο ΑΤΔ Συμβολοσειρά Μία συμβολοσειρά είναι μία συλλογή χαρακτήρων με διάταξη Bασικές πράξεις : (Είναιτοελάχιστοδυνατόσύνολοπράξεων)

Διαβάστε περισσότερα

Διερεύνηση γραφήματος

Διερεύνηση γραφήματος Διερεύνηση γραφήματος Διερεύνηση γραφήματος Ένας αλγόριθμος διερεύνησης γραφήματος επισκέπτεται τους κόμβους του γραφήματος με μια καθορισμένη στρατηγική, π.χ. κατά εύρος ή κατά βάθος. Καθοδική διερεύνηση

Διαβάστε περισσότερα

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

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

Διαβάστε περισσότερα

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

ΕΝΟΤΗΤΑ 7 ΟΥΡΕΣ ΠΡΟΤΕΡΑΙΟΤΗΤΑΣ ΣΩΡΟΙ ΕΝΟΤΗΤΑ 7 ΟΥΡΕΣ ΠΡΟΤΕΡΑΙΟΤΗΤΑΣ ΣΩΡΟΙ Ουρές Προτεραιότητας (Priority Queues) Θεωρούµε ότι τα προς αποθήκευση στοιχεία έχουν κάποια διάταξη (καθένα έχει µια προτεραιότητα). Τα προς αποθήκευση στοιχεία είναι

Διαβάστε περισσότερα

ΕΙΣΑΓΩΓΗ ΣΤΗΝ ΑΝΑΛΥΣΗ ΑΛΓΟΡΙΘΜΩΝ

ΕΙΣΑΓΩΓΗ ΣΤΗΝ ΑΝΑΛΥΣΗ ΑΛΓΟΡΙΘΜΩΝ ΕΙΣΑΓΩΓΗ ΣΤΗΝ ΑΝΑΛΥΣΗ ΑΛΓΟΡΙΘΜΩΝ Ενότητα 10β: Αλγόριθμοι Γραφημάτων-Γραφήματα- Αναπαράσταση Γραφημάτων- Διερεύνηση Πρώτα σε Πλάτος (BFS) Μαρία Σατρατζέμη Τμήμα Εφαρμοσμένης Πληροφορικής Άδειες Χρήσης Το

Διαβάστε περισσότερα

Ουρά Προτεραιότητας (priority queue)

Ουρά Προτεραιότητας (priority queue) Ουρά Προτεραιότητας (priority queue) Δομή δεδομένων που υποστηρίζει δύο βασικές λειτουργίες : Εισαγωγή στοιχείου με δεδομένο κλειδί. Επιστροφή ενός στοιχείου με μέγιστο (ή ελάχιστο) κλειδί και διαγραφή

Διαβάστε περισσότερα

Κατανεμημένα Συστήματα Ι

Κατανεμημένα Συστήματα Ι Κατανεμημένα Συστήματα Ι Εκλογή αρχηγού και κατασκευή BFS δένδρου σε σύγχρονο γενικό δίκτυο Παναγιώτα Παναγοπούλου Περίληψη Εκλογή αρχηγού σε γενικά δίκτυα Ορισμός του προβλήματος Ο αλγόριθμος FloodMax

Διαβάστε περισσότερα

Λυσεις προβλημάτων τελικής φάσης Παγκύπριου Μαθητικού Διαγωνισμού Πληροφορικής 2007

Λυσεις προβλημάτων τελικής φάσης Παγκύπριου Μαθητικού Διαγωνισμού Πληροφορικής 2007 Λυσεις προβλημάτων τελικής φάσης Παγκύπριου Μαθητικού Διαγωνισμού Πληροφορικής 2007 Πρόβλημα 1 Το πρώτο πρόβλημα λύνεται με τη μέθοδο του Δυναμικού Προγραμματισμού. Για να το λύσουμε με Δυναμικό Προγραμματισμό

Διαβάστε περισσότερα

ΑΛΓΟΡΙΘΜΟΙ. Ενότητα 9: Άπληστοι Αλγόριθμοι. Ιωάννης Μανωλόπουλος, Καθηγητής Αναστάσιος Γούναρης, Επίκουρος Καθηγητής Τμήμα Πληροφορικής ΑΠΘ

ΑΛΓΟΡΙΘΜΟΙ. Ενότητα 9: Άπληστοι Αλγόριθμοι. Ιωάννης Μανωλόπουλος, Καθηγητής Αναστάσιος Γούναρης, Επίκουρος Καθηγητής Τμήμα Πληροφορικής ΑΠΘ ΑΡΙΣΤΟΤΕΛΕΙΟ ΠΑΝΕΠΙΣΤΗΜΙΟ ΘΕΣΣΑΛΟΝΙΚΗΣ ΑΝΟΙΚΤΑ ΑΚΑΔΗΜΑΪΚΑ ΜΑΘΗΜΑΤΑ ΑΛΓΟΡΙΘΜΟΙ Ενότητα 9: Άπληστοι Ιωάννης Μανωλόπουλος, Καθηγητής Αναστάσιος Γούναρης, Επίκουρος Καθηγητής Άδειες Χρήσης Το παρόν εκπαιδευτικό

Διαβάστε περισσότερα

Θεωρία Γραφημάτων 5η Διάλεξη

Θεωρία Γραφημάτων 5η Διάλεξη Θεωρία Γραφημάτων 5η Διάλεξη Α. Συμβώνης Εθνικο Μετσοβειο Πολυτεχνειο Σχολη Εφαρμοσμενων Μαθηματικων και Φυσικων Επιστημων Τομεασ Μαθηματικων Φεβρουάριος 2016 Α. Συμβώνης (ΕΜΠ) Θεωρία Γραφημάτων 5η Διάλεξη

Διαβάστε περισσότερα

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

Κατ οίκον Εργασία 2 Σκελετοί Λύσεων Κατ οίκον Εργασία 2 Σκελετοί Λύσεων Άσκηση 1 Ο ζητούμενος ΑΤΔ μπορεί να υλοποιηθεί ως μια ακολουθία από στοιχεία τύπου window συνοδευόμενη από τις πράξεις: MakeNewWindow(L,w) Destroy(L,w) SwitchTo(L,w)

Διαβάστε περισσότερα

ΕΙΣΑΓΩΓΗ ΣΤΟΝ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟ Ενδεικτικές Απαντήσεις Εξετάσεων Α' Περιόδου Θέµα 1. (α') 2 - ii 3 - iii 4 - iv

ΕΙΣΑΓΩΓΗ ΣΤΟΝ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟ Ενδεικτικές Απαντήσεις Εξετάσεων Α' Περιόδου Θέµα 1. (α') 2 - ii 3 - iii 4 - iv ΕΙΣΑΓΩΓΗ ΣΤΟΝ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟ Ενδεικτικές Απαντήσεις Εξετάσεων Α' Περιόδου 2011 Θέµα 1 (α') 1 - i 2 - ii 3 - iii 4 - iv 5 - v 6 - vi 7 - vii 8 - viii 9 - ix 10 - x Το αποτέλεσµα είναι η αντιστοιχία των

Διαβάστε περισσότερα

ΠΑΝΕΠΙΣΤΗΜΙΟ ΚΥΠΡΟΥ ΤΜΗΜΑ ΠΛΗΡΟΦΟΡΙΚΗΣ. ΑΣΚΗΣΗ 4 Σωροί, Γράφοι

ΠΑΝΕΠΙΣΤΗΜΙΟ ΚΥΠΡΟΥ ΤΜΗΜΑ ΠΛΗΡΟΦΟΡΙΚΗΣ. ΑΣΚΗΣΗ 4 Σωροί, Γράφοι ΠΑΝΕΠΙΣΤΗΜΙΟ ΚΥΠΡΟΥ ΤΜΗΜΑ ΠΛΗΡΟΦΟΡΙΚΗΣ ΕΠΛ 231: Δομές Δεδομένων και Αλγόριθμοι Εαρινό Εξάμηνο 2013 ΑΣΚΗΣΗ 4 Σωροί, Γράφοι Διδάσκων Καθηγητής: Παναγιώτης Ανδρέου Ημερομηνία Υποβολής: 05/04/2013 Ημερομηνία

Διαβάστε περισσότερα

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

Διδάσκων: Κωνσταντίνος Κώστα Διαφάνειες: Δημήτρης Ζεϊναλιπούρ Διάλεξη 10: Λίστες Υλοποίηση & Εφαρμογές Στην ενότητα αυτή θα μελετηθούν τα εξής επιμέρους θέματα: Ευθύγραμμες Απλά Συνδεδεμένες Λίστες (εύρεση, εισαγωγή, διαγραφή) Σύγκριση Συνδεδεμένων Λιστών με Πίνακες

Διαβάστε περισσότερα

Αλγόριθμοι Ταξινόμησης Μέρος 2

Αλγόριθμοι Ταξινόμησης Μέρος 2 Αλγόριθμοι Ταξινόμησης Μέρος 2 Μανόλης Κουμπαράκης 1 Προχωρημένοι Αλγόριθμοι Ταξινόμησης Στη συνέχεια θα παρουσιάσουμε τρείς προχωρημένους αλγόριθμους ταξινόμησης: treesort, quicksort και mergesort. 2

Διαβάστε περισσότερα

Εισαγωγή στην Επιστήμη των Υπολογιστών

Εισαγωγή στην Επιστήμη των Υπολογιστών Εισαγωγή στην Επιστήμη των Υπολογιστών 4 ο εξάμηνο ΣΗΜΜΥ 5 η ενότητα: Γράφοι: προβλήματα και αλγόριθμοι Επιμέλεια διαφανειών: Στάθης Ζάχος, Άρης Παγουρτζής, Δημήτρης Φωτάκης Σχολή Ηλεκτρολόγων Μηχανικών

Διαβάστε περισσότερα

Ειδικά θέματα Αλγορίθμων και Δομών Δεδομένων (ΠΛΕ073) Απαντήσεις 1 ου Σετ Ασκήσεων

Ειδικά θέματα Αλγορίθμων και Δομών Δεδομένων (ΠΛΕ073) Απαντήσεις 1 ου Σετ Ασκήσεων Ειδικά θέματα Αλγορίθμων και Δομών Δεδομένων (ΠΛΕ073) Απαντήσεις 1 ου Σετ Ασκήσεων Άσκηση 1 α) Η δομή σταθμισμένης ένωσης με συμπίεση διαδρομής μπορεί να τροποποιηθεί πολύ εύκολα ώστε να υποστηρίζει τις

Διαβάστε περισσότερα

Μη AVL Δέντρα Εισαγωγή κόμβου 4, 6 : 4 12 :

Μη AVL Δέντρα Εισαγωγή κόμβου 4, 6 : 4 12 : AVL δέντρα AVL Δέντρα L R G.M. AdelsonVelkii και E.M. Landis 192 Μη AVL Δέντρα Εισαγωγή κόμβου, : : Αριστερή στροφή 1 8, 1 : 8 1 7 : 7 8 1 Δεξιά στροφή 8 7 Αριστερή στροφή 1 8 7 1 Περιπτώσεις LL : ο νέος

Διαβάστε περισσότερα