This shows you the differences between two versions of the page.
| Both sides previous revision Previous revision | |||
|
cpp:stl:array [2021/06/06 19:56] |
cpp:stl:array [2021/06/06 20:56] gthanos [Επίδοσης της δομής] |
||
|---|---|---|---|
| Line 1: | Line 1: | ||
| + | ====== std::array ====== | ||
| + | |||
| + | Πρόκειται για μία δομή πίνακα του οποίου το μέγεθος ορίζεται κατά τη δήλωση του πίνακα και παραμένει αμετάβλητο. Μπορείτε να διατρέξετε το πίνακα χρησιμοποιώντας // | ||
| + | |||
| + | ===== Επίδοση της δομής ===== | ||
| + | |||
| + | * Η πράξη της ένθεσης ή της διαγραφής από τον τέλος του πίνακα έχει σταθερό κόστος **(O(1))**. | ||
| + | * Η πράξη της ένθεσης ή της διαγραφής από το μέσο ή την αρχή του πίνακα συνεπάγεται την μετακίνηση όλων των στοιχείων που βρίσκονται δεξιότερα κατά μία θέση. Η επίδοση της εξαρτάται από την θέση της ένθεσης ή της διαγραφής σε σχέση με το τέλος του πίνακα. Ο επιμερισμένος χρόνος της συγκεκριμένης πράξης είναι γραμμικός στο μέγεθος των αποθηκευμένων στοιχείων του πίνακα **(Ο(Ν))**. | ||
| + | * Η πράξη της αναζήτησης είναι γραμμική στο μέγεθος των στοιχείων του πίνακα **(Ο(Ν))**. | ||
| + | * Η πρόσβαση στο i-στο στοιχείο του πίνακα έχει κόστος 1. | ||
| + | |||
| + | |||
| + | ===== Ορισμός και διάτρεξη πίνακα ===== | ||
| + | |||
| + | <code cpp array_iterator.cpp> | ||
| + | #include < | ||
| + | #include < | ||
| + | using namespace std; | ||
| + | |||
| + | int main () { | ||
| + | std:: | ||
| + | |||
| + | std::cout << " | ||
| + | for (auto it=myarray.cbegin() ; it < myarray.cend(); | ||
| + | std::cout << ' ' << *it; // cannot modify *it | ||
| + | std::cout << ' | ||
| + | | ||
| + | cout << " | ||
| + | for (auto rit=myarray.crbegin() ; rit < myarray.crend(); | ||
| + | std::cout << ' ' << *rit; // cannot modify *rit | ||
| + | std::cout << ' | ||
| + | | ||
| + | std::cout << " | ||
| + | for (auto it=myarray.cbegin() ; it < myarray.cend(); | ||
| + | *it += 10; | ||
| + | std::cout << ' ' << *it; // cannot modify *it | ||
| + | } | ||
| + | std::cout << ' | ||
| + | | ||
| + | cout << " | ||
| + | for (auto rit=myarray.rbegin() ; rit < myarray.rend(); | ||
| + | *it += 100; | ||
| + | std::cout << ' ' << *rit; // cannot modify *rit | ||
| + | } | ||
| + | std::cout << ' | ||
| + | } | ||
| + | </ | ||
| + | |||
| + | <code cpp array_for.cpp> | ||
| + | #include < | ||
| + | #include < | ||
| + | using namespace std; | ||
| + | |||
| + | int main () { | ||
| + | std:: | ||
| + | |||
| + | for(int i=0; i< | ||
| + | std::cout << ' ' << myarray[i]; | ||
| + | std::cout << endl; | ||
| + | } | ||
| + | </ | ||
| + | |||
| + | ===== Πρόσβαση στα στοιχεία του πίνακα ===== | ||
| + | |||
| + | <code cpp array_access_op[].cpp> | ||
| + | #include < | ||
| + | #include < | ||
| + | using namespace std; | ||
| + | |||
| + | int main () { | ||
| + | array< | ||
| + | |||
| + | myarray[5] = 600; | ||
| + | cout << " | ||
| + | myarray[6] = 1; | ||
| + | cout << " | ||
| + | } | ||
| + | </ | ||
| + | |||
| + | Παρατηρούμε ότι στον παραπάνω κώδικα η πρόσβαση εκτός ορίων παράγει τερματισμό του προγράμματος μέσω segmentation fault. Εάν θέλουμε να μπορούμε να ελέγχουμε τις πιθανές λανθασμένες προσπελάσεις μέσω της διαχείρισης ενός exception υπάρχει η ισοδύναμη συνάρτηση [[http:// | ||
| + | |||
| + | <code cpp array_access_at.cpp> | ||
| + | #include < | ||
| + | #include < | ||
| + | using namespace std; | ||
| + | |||
| + | int main () { | ||
| + | array< | ||
| + | |||
| + | myarray[5] = 600; | ||
| + | cout << " | ||
| + | try { | ||
| + | myarray.at(10) = 1; | ||
| + | cout << " | ||
| + | } catch(std:: | ||
| + | cout << ex.what() << endl; | ||
| + | } | ||
| + | } | ||
| + | </ | ||
| + | |||
| + | |||
| + | |||
| + | |||