Heim Backend-Entwicklung C++ Ist std::list::size() wirklich O(1) in C?

Ist std::list::size() wirklich O(1) in C?

Nov 16, 2024 pm 03:00 PM

Is std::list::size() Really O(1) in C  ?

Ist std::list::size() wirklich O(n)?

Es wurden Bedenken hinsichtlich der zeitlichen Komplexität von std geäußert ::list::size() in C . Einige vermuten, dass es möglicherweise von der Implementierung abhängt, obwohl der Standard seine Komplexität nicht spezifiziert.

Implementierungsspezifisches Verhalten

In früheren Versionen von C war die Komplexität von std: :list::size() variierte je nach verwendeter STL-Implementierung. Microsoft Visual Studio V6 implementierte es mit konstanter Komplexität, während GCC bis 4.1.0 einen distanzbasierten Ansatz verwendete, was zu O(n)-Komplexität führte.

Standardisierung und Komplexität

In C 11 wurde durch n2923 eine Änderung eingeführt, die erfordert, dass alle Standard-Container-.size()-Operationen eine konstante Zeitkomplexität (O(1)) haben müssen. Dies ist jetzt eine explizite Anforderung, die eine konsistente Leistung über alle Implementierungen hinweg gewährleistet.

GCC-Implementierung

Trotz der Standardisierung ist die Implementierung von std::list::size( ) in GCC bis Version 4.8 verwendet weiterhin einen O(n)-Algorithmus. Dies wird im Blogeintrag, der in der ursprünglichen Frage verlinkt ist, ausführlich erläutert.

Update in GCC 5.0

Es ist wichtig zu beachten, dass dieses Problem in GCC 5.0 behoben ist später. Im C 11-Modus wird std::list::size() ordnungsgemäß mit O(1)-Komplexität in GCC 5.0 und höher implementiert.

libc-Implementierung

In Im Gegensatz zum GCC-Ansatz wurde die Implementierung von std::list::size() durch libc seit ihrer Einführung konsequent für die O(1)-Komplexität optimiert.

Das obige ist der detaillierte Inhalt vonIst std::list::size() wirklich O(1) in C?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße Artikel -Tags

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Welche Werte sind von C -Sprachfunktionen zurückgegeben? Was bestimmt den Rückgabewert? Welche Werte sind von C -Sprachfunktionen zurückgegeben? Was bestimmt den Rückgabewert? Mar 03, 2025 pm 05:52 PM

Welche Werte sind von C -Sprachfunktionen zurückgegeben? Was bestimmt den Rückgabewert?

C Sprachfunktionsformat -Buchstaben -Fall -Konvertierungsschritte C Sprachfunktionsformat -Buchstaben -Fall -Konvertierungsschritte Mar 03, 2025 pm 05:53 PM

C Sprachfunktionsformat -Buchstaben -Fall -Konvertierungsschritte

GULC: C -Bibliothek von Grund auf neu gebaut GULC: C -Bibliothek von Grund auf neu gebaut Mar 03, 2025 pm 05:46 PM

GULC: C -Bibliothek von Grund auf neu gebaut

Was sind die Definitionen und Aufrufregeln von C -Sprachfunktionen und was sind die? Was sind die Definitionen und Aufrufregeln von C -Sprachfunktionen und was sind die? Mar 03, 2025 pm 05:53 PM

Was sind die Definitionen und Aufrufregeln von C -Sprachfunktionen und was sind die?

eindeutiger Gebrauch und Phrasenfreigabe eindeutiger Gebrauch und Phrasenfreigabe Mar 03, 2025 pm 05:51 PM

eindeutiger Gebrauch und Phrasenfreigabe

Wie funktioniert die C -Standard -Vorlagenbibliothek (STL)? Wie funktioniert die C -Standard -Vorlagenbibliothek (STL)? Mar 12, 2025 pm 04:50 PM

Wie funktioniert die C -Standard -Vorlagenbibliothek (STL)?

Wo ist der Rückgabewert der C -Sprachfunktion im Speicher? Wo ist der Rückgabewert der C -Sprachfunktion im Speicher? Mar 03, 2025 pm 05:51 PM

Wo ist der Rückgabewert der C -Sprachfunktion im Speicher?

Wie benutze ich Algorithmen aus der STL (sortieren, finden, transformieren usw.) effizient? Wie benutze ich Algorithmen aus der STL (sortieren, finden, transformieren usw.) effizient? Mar 12, 2025 pm 04:52 PM

Wie benutze ich Algorithmen aus der STL (sortieren, finden, transformieren usw.) effizient?

See all articles