Das Ermitteln der Summe aller Elemente in einem std::vector ist eine häufige Aufgabe mit mehreren effizienten Ansätzen. Hier sind mehrere Optionen:
For-Schleife:
int sum_of_elems = 0; for (std::vector<int>::iterator it = vector.begin(); it != vector.end(); ++it) sum_of_elems += *it;
Standardalgorithmus:
#include <numeric> sum_of_elems = std::accumulate(vector.begin(), vector.end(), 0);
Hinweis: Beachten Sie, dass der Typ des letzten Argument bestimmt den Ergebnistyp.
Automatische Typbehandlung:
#include <numeric> sum_of_elems = std::accumulate(vector.begin(), vector.end(), decltype(vector)::value_type(0));
std:: for_each:
std::for_each(vector.begin(), vector.end(), [&](int n) { sum_of_elems += n; });
Bereichsbasiert für Schleife:
for (auto& n : vector) sum_of_elems += n;
std::reduce:
#include <numeric> auto result = std::reduce(v.begin(), v.end());
std::reduce behandelt den Ergebnistyp Inferenz und bietet parallele Ausführungsfunktionen für große Sammlungen.
Das obige ist der detaillierte Inhalt vonWas sind die besten Möglichkeiten, die Elemente eines std::vector in C zu summieren?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!