Heim >Backend-Entwicklung >C++ >Was sind die effizienten Möglichkeiten, die Elemente eines std::vector in C zu summieren?
Effiziente Methoden zum Summieren von Elementen in einem std::vector
In Szenarien, in denen Sie die kumulative Summe von Elementen innerhalb eines std ermitteln müssen ::vector gibt es mehrere effiziente Ansätze.
C 03 Lösungen:
Klassische 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: Das Finale Der Typ des Arguments bestimmt den Anfangswert und den Ergebnistyp. Verwenden Sie für Gleitkomma-Eingaben 0,0 anstelle von 0.
C 11 und höher Erweiterungen:
Automatischer Vektortyp Handhabung:
#include <numeric> sum_of_elems = std::accumulate(vector.begin(), vector.end(), decltype(vector)::value_type(0));
std::for_each Nutzung:
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;
C 17 und spätere Ergänzungen:
std:: Mit automatischem Ergebnistyp reduzieren:
#include <numeric> auto result = std::reduce(v.begin(), v.end());
Die Überladungen dieser Funktion ermöglichen die Parallelverarbeitung für umfangreiche Sammlungen.
Das obige ist der detaillierte Inhalt vonWas sind die effizienten 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!