Bearbeiten von „STL C++“

Zur Navigation springen Zur Suche springen

Warnung: Du bist nicht angemeldet. Deine IP-Adresse wird bei Bearbeitungen öffentlich sichtbar. Melde dich an oder erstelle ein Benutzerkonto, damit Bearbeitungen deinem Benutzernamen zugeordnet werden.

Die Bearbeitung kann rückgängig gemacht werden. Bitte prüfe den Vergleich unten, um sicherzustellen, dass du dies tun möchtest, und veröffentliche dann unten deine Änderungen, um die Bearbeitung rückgängig zu machen.

Aktuelle Version Dein Text
Zeile 213: Zeile 213:
== Algorithmen ==
== Algorithmen ==
Arbeiten auf Containern.
Arbeiten auf Containern.
=== Find ===
* find() findet Element
* find_if() findet mittels Prädikatsfunktion (Funktion oder Lambda-Funktion).
<syntaxhighlight lang="c++">
#include <stdio.h>
#include <string>
#include <iterator>
#include <algorithm>
#include <vector>
bool isEven (int i) { return i%2==0; }
int main () {
  int myints[] = {32,71,12,45,26,80,53,33};
  std::vector<int> vec (myints, myints+8);              // 32 71 12 45 26 80 53 33
  if (std::find(vec.begin(), vec.end(), 99) != vec.end()){
    printf("99 is here");
  }
  auto it2 = std::find_if (vec.begin(), vec.end(), isEven);
  bool even = it2 != vec.end();
  printf("first even: %d", ! even ? 0 : *it2);
}
</syntaxhighlight>
=== Sort ===
=== Sort ===
* Entweder globale Funktion (oder Lambafunktion) als Parameter. Implementiert "<" Operator.
* Entweder globale Funktion (oder Lambafunktion) als Parameter. Implementiert "<" Operator.
* oder eine Klasse mit Operator ()(K i, K j) als Parameter. Implementiert "<" Operator.
* oder eine Klasse mit Operator ()(K i, K j) als Parameter. Implementiert "<" Operator.
<syntaxhighlight lang="c++">
<syntaxhighlight lang="c++">
#include <iterator>
#include <algorithm>
#include <vector>
bool compareInt (int i,int j) { return (i<j); }
bool compareInt (int i,int j) { return (i<j); }


Zeile 263: Zeile 235:
   // using object as comp
   // using object as comp
   std::sort (vec.begin(), vec.end(), data);    //(12 26 32 33 45 53 71 80)
   std::sort (vec.begin(), vec.end(), data);    //(12 26 32 33 45 53 71 80)
}
 
</syntaxhighlight>
</syntaxhighlight>


Bitte kopiere keine Webseiten, die nicht deine eigenen sind, benutze keine urheberrechtlich geschützten Werke ohne Erlaubnis des Urhebers!
Du gibst uns hiermit deine Zusage, dass du den Text selbst verfasst hast, dass der Text Allgemeingut (public domain) ist, oder dass der Urheber seine Zustimmung gegeben hat. Falls dieser Text bereits woanders veröffentlicht wurde, weise bitte auf der Diskussionsseite darauf hin. Bitte beachte, dass alle Info-Theke-Beiträge automatisch unter der „Gemeinfreiheit“ stehen (siehe Info-Theke:Urheberrechte für Einzelheiten). Falls du nicht möchtest, dass deine Arbeit hier von anderen verändert und verbreitet wird, dann klicke nicht auf „Seite speichern“.

Abbrechen Bearbeitungshilfe (wird in einem neuen Fenster geöffnet)