User Tools

Site Tools


cpp:stl:containers

Differences

This shows you the differences between two versions of the page.

Link to this comparison view

Both sides previous revisionPrevious revision
Next revision
Previous revision
Next revisionBoth sides next revision
cpp:stl:containers [2020/05/28 16:40] – [Διαγραφή στοιχείου] gthanoscpp:stl:containers [2020/05/29 08:13] – removed gthanos
Line 1: Line 1:
-====== Κοινές συναρτήσεις για όλους τους containers ====== 
  
-==== Εισαγωγή στοιχείου ==== 
- 
-Με εξαίρεση την κλάση [[array|std::array]] που το μέγεθος των πινάκων που δημιουργεί είναι σταθερό και δηλώνεται κατά τη δήλωση του πίνακα, οι υπόλοιποι //containers// μπορούν να μεταβάλλουν το αριθμό των στοιχείων που αποθηκεύουν. Για την εισαγωγή ενός στοιχείου σε έναν //container// υπάρχουν οι συναρτήσεις //insert// για την εισαγωγή ενός αντιγράφου του στοιχείου στον container και //emplace// για την δημιουργία ενός αντικειμένου και εισαγωγή του στον //container//. Επιπλέον, μόνο για τους //sequence containers// η //insert// λαμβάνει ως πρώτο όρισμα έναν //iterator// που δηλώνει τη θέση εισαγωγής του στοιχείου στον container. 
- 
-Παραδείγματα: 
-=== A. Ένθεση σε λίστα === 
- 
-<code cpp student_list_insert.cpp> 
-#include <iostream>     // std::cout 
-#include <algorithm>    // std::copy 
-#include <list>         // std::list 
-#include "Student.hpp" 
- 
-int main () { 
-  Student students[] = { Student("Peter_Pan", 1234), Student("Tinker_Bell", 1235) }; 
-                           
-  std::cerr << "----- Init list -----" << std::endl; 
-  std::list<Student> mylist; 
-  for(int i=0; i<2; i++) { 
-    mylist.insert(mylist.begin(),students[i]);  // copy-constructor, insert first 
-    mylist.insert(mylist.end(),students[i]);    // copy-constructor, insert last 
-  } 
-   
-  mylist.emplace(mylist.end(), "Mickey_Mouse", 1237);  // argument construct, insert last 
-   
-  std::cerr << "-------------------------\n"; 
-  std::cerr << "mylist contains:"; 
-  for (std::list<Student>::iterator it = mylist.begin(); it!=mylist.end(); ++it) 
-    std::cerr << ' ' << *it; 
-  std::cerr << std::endl; 
-  std::cerr << "-------------------------\n"; 
-   
-  return 0; 
- 
-</code> 
- 
-=== Β. Ένθεση σε set === 
- 
-<code cpp string_set_insert.cpp> 
-#include <iostream>     // std::cout 
-#include <algorithm>    // std::copy 
-#include <set>       // std::set 
-#include <string> 
- 
-int main () { 
-  std::string strings[] = { std::string("gamma"), std::string("beta"), std::string("delta") }; 
-                           
-  std::cerr << "----- Init set -----" << std::endl; 
-  std::set<std::string> myset; 
-  for(int i=0; i<3; i++)  
-    myset.insert(strings[i]); 
-   
-  myset.emplace("alpha");  // argument construct, insert last 
-   
-  std::cerr << "-------------------------\n"; 
-  std::cerr << "myset contains:"; 
-  for (std::set<std::string>::iterator it = myset.begin(); it!=myset.end(); it++) 
-    std::cerr << ' ' << *it; 
-  std::cerr << std::endl; 
-  std::cerr << "-------------------------\n"; 
-   
-  return 0; 
- 
-</code> 
- 
-==== Διαγραφή στοιχείου ==== 
- 
-Η διαγραφή στοιχείου είναι ανάλογη της εισαγωγής και γίνεται μέσω της συνάρτησης //erase//. H συνάρτηση επιστρέφει έναν //iterator// στο επόμενο στοιχείο από αυτό που έχει διεγραφεί. Για τους //sequence containers// σε αναλογία με την διαδικασία εισαγωγής, η συνάρτηση λαμβάνει ως όρισμα έναν //iterator// που δηλώνει τη θέση διαγραφής από τον container. Για τους //associative containers// η διαγραφή γίνεται παρέχοντας ως όρισμα τη θέση του κλειδιού (μέσω //iterator//) ή την τιμή του κλειδιού που επιθυμούμε να διαγράψουμε. 
- 
-=== Διαγραφή από λίστα === 
- 
-Το παρακάτω παράδειγμα είναι από τη σελίδα [[http://www.cplusplus.com/reference/list/list/erase/|http://cplusplus.com/list/erase]] 
- 
-<code cpp list_erase.cpp> 
-#include <iostream> 
-#include <list> 
- 
-int main () { 
-  std::list<int> mylist; 
-  std::list<int>::iterator it1, it2; 
- 
-  // insert values: 
-  for (int i=1; i<10; ++i) mylist.push_back(i*10); 
- 
-                              // 10 20 30 40 50 60 70 80 90 
-  it1 = it2 = mylist.begin(); // ^^ 
-  advance (it2,6);            // ^                 ^ 
-  ++it1;                      //    ^              ^ 
- 
-  it1 = mylist.erase (it1);   // 10 30 40 50 60 70 80 90 
-                              //    ^           ^ 
- 
-  it2 = mylist.erase (it2);   // 10 30 40 50 60 80 90 
-                              //    ^           ^ 
-                              // 10 30 40 50 60 80 90 
-  ++it1;                      //              ^ 
-  --it2;                      //           ^ 
- 
-  it1=mylist.erase (it1,it2); // 10 30 60 80 90 
-                              //        ^ 
- 
-  std::cout << "mylist contains:"; 
-  for (it1=mylist.begin(); it1!=mylist.end(); ++it1) 
-    std::cout << ' ' << *it1; 
-  std::cout << '\n'; 
- 
-  return 0; 
-</code> 
- 
- 
-=== Διαγραφή από set === 
- 
-Το παρακάτω παράδειγμα είναι από τη σελίδα [[http://www.cplusplus.com/reference/set/erase/|http://cplusplus.com/set/erase]] 
- 
-<code cpp set_erase.cpp> 
-// erasing from set 
-#include <iostream> 
-#include <set> 
- 
-int main () 
-{ 
-  std::set<int> myset; 
-  std::set<int>::iterator it; 
- 
-  // insert some values: 
-  for (int i=1; i<10; i++) myset.insert(i*10);  // 10 20 30 40 50 60 70 80 90 
- 
-  it = myset.begin();                           // 10 20 30 40 50 60 70 80 90 
-                                                //  ^  
-  ++it;                                         // 10 20 30 40 50 60 70 80 90 
-                                                //      
- 
-  myset.erase (it);                             // 10 30 40 50 60 70 80 90 
- 
-  myset.erase (40);                             // 10 30 50 60 70 80 90 
- 
-  it = myset.find (60);                         // 10 30 50 60 70 80 90 
-                                                //           ^ 
-  myset.erase (it, myset.end());                // 10 30 50 
- 
-  std::cout << "myset contains:"; 
-  for (it=myset.begin(); it!=myset.end(); ++it) 
-    std::cout << ' ' << *it; 
-  std::cout << '\n'; 
- 
-  return 0; 
-} 
-</code> 
cpp/stl/containers.txt · Last modified: 2022/05/26 16:49 by gthanos