User Tools

Site Tools


cpp:stl:container_common_functions

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:container_common_functions [2022/06/01 03:36] – [Ανάθεση των περιεχομένων ενός container από τα περιεχόμενα ενός άλλου container] gthanoscpp:stl:container_common_functions [2023/05/29 16:33] – [Ανάθεση των περιεχομένων ενός container από τα περιεχόμενα ενός άλλου container] gthanos
Line 7: Line 7:
 Παραδείγματα: Παραδείγματα:
  
-==== A. Ένθεση σε λίστα ====+==== A. Ένθεση στους sequence_containers list, forward_list, vector και dequeue ====
  
 Σε ένα //sequence container// είναι υποχρεωτικό να προσδιορίσουμε τη θέση εισαγωγής του στοιχείου μέσω ενός //iterator// που παρέχεται ως πρώτο όρισμα στη συνάρτηση //insert//. Σε ένα //sequence container// είναι υποχρεωτικό να προσδιορίσουμε τη θέση εισαγωγής του στοιχείου μέσω ενός //iterator// που παρέχεται ως πρώτο όρισμα στη συνάρτηση //insert//.
Line 40: Line 40:
 </code> </code>
  
-==== Β. Ένθεση σε set ====+<WRAP tip 80% center round> 
 +Η διαφορά ανάμεσα στις μεθόδους //insert// και //emplace// είναι η εξής:  
 +  * Στη μέθοδο //insert// παρέχουμε ένα αντικείμενο και η μέθοδος κατασκευάζει ένα αντίγραφο του μέσω του κατασκευαστή αντιγραφέα (copy-constructor) της κλάσης //Student//
 +  * Στη μέθοδο //empace// παρέχουμε τα ορίσματα μέσω των οποίων κατασκευάζεται ένα αντικείμενο τύπου Student, μέσω του κατασκευαστή ''Student(const char *name, int aem);''
 +</WRAP> 
 + 
 +==== Β. Ένθεση σε set, unordered set ====
  
 Σε ένα //associative container// δεν μπορούμε να προσδιορίσουμε τη θέση εισαγωγής του στοιχείου σε αυτόν. Ως εκ τούτου η //insert// δεν λαμβάνει ως πρώτο όρισμα έναν //iterator//. Σε ένα //associative container// δεν μπορούμε να προσδιορίσουμε τη θέση εισαγωγής του στοιχείου σε αυτόν. Ως εκ τούτου η //insert// δεν λαμβάνει ως πρώτο όρισμα έναν //iterator//.
Line 53: Line 59:
   Student students[] = { Student("Peter_Pan", 1234), Student("Tinker_Bell", 1235) };   Student students[] = { Student("Peter_Pan", 1234), Student("Tinker_Bell", 1235) };
                                                      
-  std::cerr << "----- Init list -----" << std::endl; +  std::cerr << "----- Init set -----" << std::endl; 
-  std::set<Student> mylist;+  std::set<Student> myset;
   for(int i=0; i<2; i++) {   for(int i=0; i<2; i++) {
-    mylist.insert(students[i]);  // copy-constructor, insert first +    myset.insert(students[i]);  // copy-constructor, insert first 
-    mylist.insert(students[i]);    // copy-constructor, insert last+    myset.insert(students[i]);    // copy-constructor, insert last
   }   }
      
-  mylist.emplace("Mickey_Mouse", 1237);  // argument construct, insert last+  myset.emplace("Mickey_Mouse", 1237);  // argument construct, insert last
      
   std::cerr << "-------------------------\n";   std::cerr << "-------------------------\n";
-  std::cerr << "mylist contains:"; +  std::cerr << "myset contains:"; 
-  for (std::set<Student>::iterator it = mylist.begin(); it!=mylist.end(); ++it)+  for (std::set<Student>::iterator it = myset.begin(); it!=myset.end(); ++it)
     std::cerr << ' ' << *it;     std::cerr << ' ' << *it;
   std::cerr << std::endl;   std::cerr << std::endl;
Line 269: Line 275:
   if(it != myset.end()) {   if(it != myset.end()) {
     myset.erase (it);     myset.erase (it);
-    std::cout << "'buiscuits' erased\n";+    std::cout << "'biscuits' erased\n";
   }   }
   else    else 
-    std::cout << "'buiscuits' not found\n";+    std::cout << "'biscuits' not found\n";
      
   print_set(myset);   print_set(myset);
Line 306: Line 312:
  
 int main () { int main () {
-  vector<int> v;+  vector<int>= {1,2,3};
   array<int,6> a = {10, 20, 30, 40, 50, 60};   array<int,6> a = {10, 20, 30, 40, 50, 60};
      
cpp/stl/container_common_functions.txt · Last modified: 2023/05/30 19:18 by gthanos