Namensräume
Varianten
Aktionen

std::flat_map<Key,T,Compare,KeyContainer,MappedContainer>::replace

Von cppreference.com
< cpp‎ | container‎ | flat map
 
 
 
 
void replace( key_container_type&& key_cont, mapped_container_type&& mapped_cont );
(seit C++23)

Ersetzt die zugrundeliegenden Container c. Entspricht

c.keys = std::move(key_cont);
c.values = std::move(mapped_cont);

Die folgenden Bedingungen müssen erfüllt sein

  • Der Ausdruck key_cont.size() == mapped_cont.size() ist true,
  • Die Elemente von key_cont sind sortiert bezüglich compare, und
  • key_cont enthält keine gleichen Elemente.

    Andernfalls ist das Verhalten undefiniert.

Inhalt

[bearbeiten] Parameter

keys_cont - ein sortierter Schlüsselcontainer vom Typ KeyContainer, dessen Inhalt in *this verschoben wird
mapped_cont - ein Container für zugeordnete Werte vom Typ MappedContainer, dessen Inhalt in *this verschoben wird

[bearbeiten] Rückgabewert

(keine)

[bearbeiten] Komplexität

Entspricht der Komplexität von std::move angewendet auf die angepassten Container.

[bearbeiten] Beispiel

#include <algorithm>
#include <cassert>
#include <flat_map>
#include <print>
#include <vector>
 
int main()
{
    std::vector<int> keys{1, 2, 3};
    assert(std::ranges::is_sorted(keys));
    std::vector<double> values{2.2, 3.3, 1.1};
    assert(keys.size() == values.size());
 
    std::flat_map<int, double> map;
    assert(map.empty());
 
    map.replace(keys, values);
    assert(map.size() == 3);
    assert(map.keys() == 3);
    assert(map.values() == 3);
    assert(keys.empty());
    assert(values.empty());
 
    std::println("{}", map);
}

Ausgabe

{1: 2.2, 2: 3.3, 3: 1.1}

[bearbeiten] Siehe auch

extrahiert die zugrunde liegenden Container
(public member function) [edit]