Εργαστήριο 2: Πίνακες



Σχετικά έγγραφα
Εργαστήριο 6: Αναζήτηση, Ανάλυση Πολυπλοκότητας

Διάλεξη 09: Αλγόριθμοι Ταξινόμησης I

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

οµές (structures) Στην ενότητα αυτή θα µελετηθούν τα εξής επιµέρους θέµατα: Πίνακες δοµών, δείκτες σε δοµές, και αυτοαναφορικές δοµές.

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

Διάλεξη 4: Προγραμματισμός σε JAVA IΙ. Διδάσκων: Παναγιώτης Ανδρέου

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

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

Εργαστηριακή Άσκηση 1

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

Διάλεξη 04: Παραδείγματα Ανάλυσης

Γ7.5 Αλγόριθμοι Αναζήτησης. Γ Λυκείου Κατεύθυνσης

Διάλεξη 04: Παραδείγματα Ανάλυσης Πολυπλοκότητας/Ανάλυση Αναδρομικών Αλγόριθμων

ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι 4. Παραδείγματα Ανάλυσης Πολυπλοκότητας Ανάλυση Αναδρομικών Αλγόριθμων

Διδάσκων: Κωνσταντίνος Κώστα Διαφάνειες: Δημήτρης Ζεϊναλιπούρ ΕΠΛ 035 Δομές Δεδομένων και Αλγόριθμοι για Ηλ. Μηχ. και Μηχ. Υπολ.

Διδάσκων: Κωνσταντίνος Κώστα Διαφάνειες: Δημήτρης Ζεϊναλιπούρ ΕΠΛ 035 Δομές Δεδομένων και Αλγόριθμοι για Ηλ. Μηχ. και Μηχ. Υπολ.

Διάλεξη 17η: Ταξινόμηση και Αναζήτηση

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

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

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

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

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

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

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

242 -ΕισαγωγήστουςΗ/Υ

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

Αναζήτηση και ταξινόμηση

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

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

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

Διάλεξη 09: Αλγόριθμοι Ταξινόμησης I

#include <stdlib.h> Α. [-128,127] Β. [-127,128] Γ. [-128,128]

Στόχοι και αντικείμενο ενότητας. Πέρασμα Πίνακα σε Συνάρτηση (συν.) Πέρασμα Πίνακα σε Συνάρτηση. #8.. Ειδικά Θέματα Αλγορίθμων

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

ΗΥ-150. Ταξινόµηση και Αναζήτηση

ΑΡΧΕΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ

Ερώτημα Α 1. Να γράψετε τις εντολές που πραγματοποιούν τα ακόλουθα:

Διάλεξη 19: Αλγόριθμοι ΤαξινόμησηςII. Διδάσκων: Παναγιώτης Ανδρέου

Προγραμματισμός Ι (HY120)

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

Εργαστήριο 8: Αναδρομική διεργασία εισαγωγής καινούριου κόμβου σε ΔΔΑ

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

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

Προγραμματιστικές Τεχνικές

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

Α Β Γ static; printf("%c\n", putchar( A +1)+2); B DB BD. int i = 0; while (++i); printf("*");

Προγραμματισμός Η/Υ (ΤΛ2007 )

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

Προγραμματισμό για ΗΜΥ

Διάλεξη 17: O Αλγόριθμος Ταξινόμησης HeapSort

Προγραμματισμός Η/Υ. Ενότητα 8: Ειδικά Θέματα Αλγορίθμων

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

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

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

Ενότητα: Δυαδική Αναζήτηση Σχέδιο Δραστηριότητας: Παιχνίδι: Βρες τον αριθμό

Αλγόριθμοι Αναζήτησης

Εργαστήριο 7: Ο αλγόριθμος ταξινόμησης Radix Sort

Προγραμματιστικές Τεχνικές

υναµική έσµευση Μνήµης (συν.) ΕΠΛ 132 Αρχές Προγραµµατισµού ΙΙ 2 Εφαρµογή

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

Δομημένος Προγραμματισμός (ΤΛ1006)

Παρακάτω δίνεται o σκελετός προγράμματος σε γλώσσα C. Σχολιάστε κάθε γραμμή του κώδικα.

Μεθόδων Επίλυσης Προβλημάτων

που θα δώσει αποτέλεσµα 48, λόγω της αριστερής προσεταιριστικότητας των τελεστών / και *, ενώ η επιθυµητή αντικατάσταση θα ήταν η

Προχωρημένες έννοιες προγραμματισμού σε C

Διάλεξη 2: Επανάληψη Προγραμματισμού Συμβολοσειρές (strings) Διδάσκων: Παναγιώτης Ανδρέου

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

Κεφάλαιο 8.6. Πίνακες ΙI (Διάλεξη 17)

Μεθόδων Επίλυσης Προβλημάτων

Αλγόριθμοι ταξινόμησης

Διαδικασιακός Προγραμματισμός

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

Δυναμικός Κατακερματισμός. Βάσεις Δεδομένων Ευαγγελία Πιτουρά 1

Προγραµµατισµός 1 Ταξινόµηση - Αναζήτηση

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

Ανάλυση αλγορίθμων. Χρόνος εκτέλεσης: Αναμενόμενη περίπτωση. - απαιτεί γνώση της κατανομής εισόδου

Εργαστήριο 1: Επανάληψη Βασικών Εννοιών στη Γλώσσα C

Α' Εξάμηνο ΕΙΣΑΓΩΓΗ ΣΤΟ ΔΟΜΗΜΕΝΟ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟ. Ασκήσεις Επανάληψης

Προγραμματισμός Ι (HY120)

ΑΡΧΕΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ

Κεφάλαιο 8.7. Πολυδιάστατοι Πίνακες (Διάλεξη 19)

i : 0<=i<N-1 => data[i] <= data[i+1] 25/10/2009

Προγραμματιστικές Ασκήσεις, Φυλλάδιο 1

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

Ενώσεις δεδομένων Απαριθμητές Ψηφιακοί τελεστές Αναδρομικές συναρτήσεις

Π. Σταθοπούλου ή Οµάδα Α (Φοιτητές µε µονό αριθµό Μητρώου ) ιδασκαλία : Παρασκευή 11πµ-13µµ ΗΛ7

Προγραμματισμός Η/Υ (ΤΛ2007 )

Σημειώσεις δεύτερης εβδομάδας

ΚΑΤΑΣΚΕΥΑΣΤΕΣ ΑΝΤΙΓΡΑΦΗΣ

Προγραμματισμός Υπολογιστών με C++

Δυναμικός Κατακερματισμός. Βάσεις Δεδομένων Ευαγγελία Πιτουρά 1

Επεξεργασία Αρχείων Κειµένου

Εισαγωγή στον Προγραμματισμό

Μεθόδων Επίλυσης Προβλημάτων

Πληροφορική 2. Αλγόριθμοι

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

Π. Σταθοπούλου ή Οµάδα Α (Φοιτητές µε µονό αριθµό Μητρώου ) ιδασκαλία : Παρασκευή 11πµ-13µµ ΗΛ7

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

Ανάπτυξη Μεγάλων Εφαρµογών στη Γλώσσα C (2)

Εισαγωγή στον Προγραµµατισµό. Πανεπιστήµιο Θεσσαλίας Τµήµα Ηλεκτρολόγων Μηχανικών και Μηχανικών Η/Υ

Transcript:

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

Δυαδική Αναζήτηση σε πίνακες: BinarySearch BinarySearch: ο αλγόριθμος αυτός βρίσκει ένα στοιχείο σε μία ταξινομημένη λίστα ψάχνοντας κάθε φορά στη μέση του πίνακα. Αν το στοιχείο είναι μεγαλύτερο τότε ο πίνακας μοιράζεται στη μέση και χρησιμοποιείται μόνο το δεξί κομμάτι στο επόμενο βήμα. 0 1 2 3 4 5 Κλειδί=8 1 2 3 4 5 6 6 7 8 7 8 9 Κλειδί=8 0 1 2 3 4 5 1 2 3 4 5 6 6 7 8 7 8 9 Κλειδί=8 0 1 2 3 4 5 1 2 3 4 5 6 6 7 8 7 8 9 ΕΠΛ035 Δομές Δεδομένων και Αλγόριθμοι για Ηλ. Μηχ. Και Μηχ. Υπολ. 2

Δυαδική Αναζήτηση σε πίνακες: BinarySearch(συν.) Πρότυπο Συνάρτησης int binarysearch(int x[], //ο πίνακας int length, //το μέγεθος του x int key) //το κλειδί αναζήτησης Αλγόριθμος Αρχικοποίησε μία μεταβλητή low να δείχνει στην αρχή του πίνακα Αρχικοποίησε μία μεταβλητή high να δείχνει στo τέλος του πίνακα Με ένα βρόγχοwhile έλεγχε σε κάθε βήμα αν το high είναι μεγαλύτερο του low και κάνε το εξής: Υπολόγισε τη μέση του πίνακα mid = (low + high) / 2 Αν το κλειδί είναι μικρότερο του στοιχείου που βρίσκεται στη θέση mid τότε θέσε σαν high την τιμή mid-1. Αν το κλειδί είναι μεγαλύτερο του στοιχείου που βρίσκεται στη θέση mid τότε θέσε σαν low την τιμή mid+1. Αλλιώς έχεις βρει το κλειδί και επέστρεψε τη θέση του, δηλ. Mid Αν τελειώσει ο βρόγχος και δεν έχεις βρει το στοιχείο τότε επέστρεψε -1 ΕΠΛ035 Δομές Δεδομένων και Αλγόριθμοι για Ηλ. Μηχ. Και Μηχ. Υπολ. 3

Ταξινόμηση με επιλογή: SelectionSort SelectionSort: ο αλγόριθμος αυτός ταξινομεί μία λίστα με στοιχεία. Σε κάθε βήμα iβρίσκει το τοi-οστό πιο μικρό στοιχείο και το τοποθετεί στην θέση i. Παράδειγμα: intx = {4, 8, 2, 1, 3, 5; swap Βήμα 1 0 1 2 3 4 5 4 8 2 1 3 5 Βήμα 2 Βήμα 3 Βήμα 4 Βήμα 5 Βήμα 6 1 8 2 4 3 5 1 2 8 4 3 5 1 2 3 4 8 5 1 2 3 4 8 5 1 2 3 4 5 8 ΕΠΛ035 Δομές Δεδομένων και Αλγόριθμοι για Ηλ. Μηχ. Και Μηχ. Υπολ. 4

Ταξινόμηση με επιλογή: SelectionSort(συν.) Πρότυπο Συνάρτησης void selectionsort(int x[], //ο πίνακας int length) //το μέγεθος του x Αλγόριθμος Αρχικοποίησε μία μεταβλητή min_indexη οποία θα αποθηκεύει τη θέση του ελάχιστου αριθμού Με ένα βρόγχοfor που θα ελέγχει ένα ένατα στοιχεία του πίνακα (i<length) κάνε τα εξής: Θέσε σαν min_indexτο i Ψάξε ένα-ένα τα στοιχεία με ένα δεύτερο εσωτερικό βρόγχο αρχίζοντας από j=i Αν το στοιχείο που βρίσκεται στη θέση jείναι μικρότερο από το στοιχείο που βρίσκεται στη θέση min_index τότε θέσε min_index = j Με την έξοδο από το βρόγχο, αντάλλαξε τα στοιχεία που βρίσκονται στη θέση i με το στοιχείο που βρίσκεται στη θέση min_index ΕΠΛ035 Δομές Δεδομένων και Αλγόριθμοι για Ηλ. Μηχ. Και Μηχ. Υπολ. 5

Υλοποίηση Υλοποιήστε τις ακόλουθες συναρτήσεις: void printarray(int x[], int length) Τυπώνει ένα πίνακα x με μέγεθος length int binarysearch(int x[], int length, int key) Εκτελεί δυαδική αναζήτηση για εύρεση του κλειδιού keyσε ένα πίνακα x με μέγεθος length void selectionsort(int x[], int length) Ταξινομεί τον πίνακα x με μέγεθος length ΕΠΛ035 Δομές Δεδομένων και Αλγόριθμοι για Ηλ. Μηχ. Και Μηχ. Υπολ. 6

Έλεγχος Για έλεγχο του προγράμματός σας υλοποιήστε την μέθοδο main ακριβώς όπως φαίνεται πιο κάτω: int main(int argc, char* argv[]) { int x[] = {4, 8, 2, 1, 3, 5; int length = 6; printarray(x,length); //Τυπώνει 4 8 2 1 3 5 selectionsort(x,length); printarray(x,length); //Τυπώνει 1 2 3 4 5 8 printf("%d\n",binarysearch(x, length, 2)); //Τυπ. 1 printf("%d\n",binarysearch(x, length, 8)); //Τυπ. 5 printf("%d\n",binarysearch(x, length, 9)); //Τυπ.-1 ΕΠΛ035 Δομές Δεδομένων και Αλγόριθμοι για Ηλ. Μηχ. Και Μηχ. Υπολ. 7

Λύσεις void selectionsort(int x[], int length){ int min_index; int tmp; for(int i=0; i<length; i++){ min_index = i; for(int j=i+1; j<length; j++){ if(x[j]<x[min_index]) min_index=j; tmp = x[i]; x[i] = x[min_index]; x[min_index]=tmp; ΕΠΛ035 Δομές Δεδομένων και Αλγόριθμοι για Ηλ. Μηχ. Και Μηχ. Υπολ. 8

Λύσεις (συν.) int binarysearch(int x[], int length, int key) { int low=0; int high = length - 1; int mid; while( high >= low) { mid = (low + high) / 2; if( key < x[mid]) high = mid-1; else if (key > x[mid]) low = mid+1; else { return mid; break; return -1; ΕΠΛ035 Δομές Δεδομένων και Αλγόριθμοι για Ηλ. Μηχ. Και Μηχ. Υπολ. 9

Λύσεις (συν.) void printarray(int x[], int length) { for(int i=0; i<length; i++){ printf("%d ", x[i]); printf("\n"); ΕΠΛ035 Δομές Δεδομένων και Αλγόριθμοι για Ηλ. Μηχ. Και Μηχ. Υπολ. 10

Λύσεις (συν.) int main(int argc, char* argv[]) { int x[] = {4, 8, 2, 1, 3, 5; int length = 6; printarray(x,length); selectionsort(x,length); printarray(x,length); printf("%d\n", binarysearch(x, length, 2)); printf("%d\n", binarysearch(x, length, 8)); printf("%d\n", binarysearch(x, length, 9)); return 0; ΕΠΛ035 Δομές Δεδομένων και Αλγόριθμοι για Ηλ. Μηχ. Και Μηχ. Υπολ. 11