logo

UNORDERED_MAP EM C++

O mapa não ordenado é um contêiner associado que contém elementos criados pela fusão de um valor mapeado com um valor-chave. O elemento é identificado especificamente por seu valor chave , e a valor mapeado é o conteúdo relacionado à chave. Chaves e valores podem ser de qualquer valor estabelecido ou tipo definido pelo usuário . Um mapa não ordenado pode ser pensado como uma estrutura de dados do tipo dicionário que armazena elementos dentro de si. Os pares sequenciais que ele contém (valor chave) permitir a recuperação rápida de um elemento específico usando sua chave individual.

A chave fornecida ao mapa é hash nos índices de uma tabela hash, razão pela qual a velocidade da estrutura de dados depende fortemente da função hash, mas em média, o custo de pesquisar, inserir e excluir da tabela hash é o(1).

é gordura protéica

Na pior das hipóteses, especialmente para números inteiros primos grandes, é complexidade de tempo pode variar de o(1) para sobre) . É altamente recomendável utilizar um mapa neste caso para evitar receber um título (tempo limite excedido) emitir.

Sintaxe:

 Unordered_mapumap 

Exemplo:

 //A c++ program to check an unordered map in it. #include #include using namespace std; int main() { unordered_mapumap; umap[&apos;javatpoint&apos;] = 20; umap[&apos;regular&apos;] = 30; umap[&apos;distribute&apos;] = 40; for (auto y :umap) cout&lt;<y.first<< ' << y.second<<endl; } < pre> <p> <strong>Output</strong> </p> <pre> Distribute 40 Regular 30 Javatpoint 20 </pre> <p> <strong>Explanation:</strong> </p> <p>This output specifically justifies the fact that the <strong> <em>unordered map&apos;s</em> </strong> output value is generated in a random <strong> <em>key-to-value</em> </strong> manner while the map shows value and key in an ordered fashion.</p> <h2>Unordered set vs Unordered map</h2> <p>Some differences between Unordered set and Unordered map are as follows:</p> <h3>Unordered map</h3> <ul> <li>Only <strong> <em>(key-value)</em> </strong> pairs are found in the elements of an <strong> <em>unordered map</em> </strong> .</li> <li>Use the operator <strong>&apos;[]&apos;</strong> to extract a key&apos;s corresponding value from a map.</li> </ul> <h3>Unordered set</h3> <ul> <tr><td> <em>Key-value</em> </td> pairs are mostly utilised to determine whether a set is present or absent and are not always present in an unordered set. <li>Using the <strong> <em>find() function</em> </strong> , an element is searched for. Thus, there is no need for an operator.</li> </tr></ul> <p> <strong>Important point:</strong> </p> <p>For instance, take the issue of counting the frequency of individual words. Since, counts cannot be stored in <strong> <em>unordered set (or set),</em> </strong> we must instead use unordered map.</p> <h2>Map vs. Unordered map</h2> <p>Some differences between the Map and Unordered map are as follows:</p> <h3>Unordered map</h3> <ul> <li>Any order may be used to store the unordered map key.</li> <li>The implementation of unordered map results in an uneven tree structure, making it impossible to retain the order of the entries.</li> <li>Operations on an unordered map typically have an <strong> <em>o(1) time complexity</em> </strong> .</li> </ul> <h3>Map</h3> <ul> <li>The map is an ordered list of distinct keys.</li> <li>It is possible to preserve the elements&apos; order (by specific tree traversal) because map uses a balanced tree structure.</li> <li>The map operations have an <strong> <em>o time complexity (log n)</em> </strong> .</li> </ul> <h2>Procedures for unordered map</h2> <p>There are numerous functions that can be used with unordered map. The ones who are most helpful are:</p> <ul> <li>Operator =</li> <li>Operator[]</li> <li>Beginning and ending of the iterator</li> <li>Empty</li> <li>Size of the capacity</li> <li>For a lookup, locate and count.</li> <li>Insert and delete</li> </ul> <p>The full list of an unordered map&apos;s methods is shown below:</p> <p> <strong>At():</strong> </p> <p>This c++ unordered map method <strong> <em>returns</em> </strong> a reference to the value with the specified element as the <strong> <em>key k</em> </strong> .</p> <p> <strong>Begin():</strong> </p> <p>It provides a return value that is an <strong> <em>iterator pointing</em> </strong> to the first entry in the unordered map container.</p> <p> <strong>End():</strong> </p> <p>The unordered map container bucket returns an <strong> <em>iterator pointing</em> </strong> to the location after the final element ().</p> <p> <strong>Bucket():</strong> </p> <p>It returns the bucket number in the map&apos;s bucket count where the element with <strong> <em>key k</em> </strong> is placed.</p> <p> <strong>Bucket_count()</strong> </p> <p>The unordered map&apos;s total number of buckets is <strong> <em>tallied</em> </strong> using the bucket count function. It can be called without passing any parameters.</p> <p> <strong>Bucket size</strong> </p> <p>It gives the unordered map count&apos;s element count for each <strong> <em>bucket ()</em> .</strong> </p> <p> <strong>Count()</strong> </p> <p>It gives the unordered map count&apos;s element count for each <strong> <em>bucket ()</em> </strong> the number of elements in an unordered map with the specified key equal range should be counted.</p> <p> <strong>Equal_eange()</strong> </p> <p>It returns the boundaries of a range with all the container&apos;s items and a key that compares to <strong> <em>k</em> </strong> .</p> <p> <strong>Find()</strong> </p> <p>Gives an iterator to the element&apos;s empty.</p> <p> <strong>Position ()</strong> </p> <p>It determines whether the unordered map container&apos;s container is empty.</p> <p> <strong>Erase()</strong> </p> <p>Elements in the unordered map container can be deleted using the <strong> <em>erase()</em> </strong> function.</p> <p>Although the functions to view the internal bucket size, bucket count, used hash function, and various hash policies are also provided by the <strong> <em>c++11 library</em> </strong> , they are less helpful in practical applications. Using iterator, we may loop through every element in the unordered map.</p> <h3>Example:</h3> <pre> #include #include using namespace std; int main() { // when we will declare a umap it must be of type and here the key will be of string type and the mapped value of double in nature unordered_mapumap = { //in this we will insert the element in map directly {&apos;one&apos;, 1}, {&apos;two&apos;, 2}, {&apos;three&apos;, 3} }; // here wi will insert the values by the help of the [] operator umap[&apos;the value of pi&apos;] = 3.14; umap[&apos;the value of root2&apos;] = 1.414; umap[&apos;the value ofroot3&apos;] = 1.732; umap[&apos;the value oflog10&apos;] = 2.302; umap[&apos;the value ofloge&apos;] = 1.0; // inserting value by insert function umap.insert(make_pair(&apos;e&apos;, 2.718)); string key = &apos;the value of pi&apos;; // if key not found in map iterator // to end is returned if (umap.find(key) == umap.end()) cout&lt;&lt; key &lt;<' cannot retrieved

'; if key found then iterator to that is returned else cout<< 'retrieved '<< << '

'; ; (umap.find(key)="=" umap.end()) <<' retrieved
'; 'found <<endl; now we will iterate over all value of umap unordered_map::iterator itr; '
the entire elements : 
'; for (itr="umap.begin();" itr !="umap.end();" itr++) { cout<first ' <second } return 0; < pre> <p> <strong>Output</strong> </p> <pre> Retrieved the value of pi Lambda value cannot retrieved The entire elements : E 2.718 The value ofloge 1 The value oflog10 2.302 The value of root2 1.414 The value ofroot3 1.732 The value of pi 3.14 Two 2 Three 3 One 1 </pre> <h3>Example:</h3> <pre> // It is a c++ program to find rhefreqency of it ,in this we will use of unordered_map of every word #include using namespace std; void printfrequencies(const string &amp;str) { unordered_mapwordfreq; stringstream ss(str); string word; while (ss&gt;&gt; word) wordfreq[word]++; unordered_map:: iterator q; for (q = wordfreq.begin(); q != wordfreq.end(); q++) cout&lt;&lt; &apos;(&apos; <first << ', ' <second ')
'; } int main() { string str="java t points questions " 'learn programs'; printfrequencies(str); return 0; < pre> <p> <strong>Output</strong> </p> <pre> (programs, 1) (learn, 1) (questions, 1) (t, 1) (points, 1) (java, 1) </pre> <hr></first></pre></'></pre></y.first<<>

Explicação:

Este resultado justifica especificamente o facto de o mapa não ordenado o valor de saída é gerado aleatoriamente chave-valor maneira enquanto o mapa mostra o valor e a chave de maneira ordenada.

Conjunto não ordenado vs mapa não ordenado

Algumas diferenças entre o conjunto não ordenado e o mapa não ordenado são as seguintes:

Mapa não ordenado

  • Apenas (valor chave) pares são encontrados nos elementos de um mapa não ordenado .
  • Use o operador '[]' para extrair o valor correspondente de uma chave de um mapa.

Conjunto não ordenado

    Valor chave os pares são utilizados principalmente para determinar se um conjunto está presente ou ausente e nem sempre estão presentes em um conjunto não ordenado.
  • Usando o função localizar() , um elemento é pesquisado. Assim, não há necessidade de operador.

Ponto importante:

Por exemplo, tomemos a questão de contar a frequência de palavras individuais. Como as contagens não podem ser armazenadas em conjunto não ordenado (ou conjunto), em vez disso, devemos usar um mapa não ordenado.

Mapa vs. Mapa não ordenado

Algumas diferenças entre o mapa e o mapa não ordenado são as seguintes:

Mapa não ordenado

  • Qualquer ordem pode ser usada para armazenar a chave do mapa não ordenada.
  • A implementação do mapa não ordenado resulta em uma estrutura de árvore irregular, impossibilitando manter a ordem das entradas.
  • As operações em um mapa não ordenado normalmente têm um o(1) complexidade de tempo .

Mapa

  • O mapa é uma lista ordenada de chaves distintas.
  • É possível preservar a ordem dos elementos (por meio de passagem específica em árvore) porque o mapa usa uma estrutura de árvore balanceada.
  • As operações do mapa têm um o complexidade de tempo (log n) .

Procedimentos para mapa não ordenado

Existem inúmeras funções que podem ser usadas com mapas não ordenados. Os que são mais úteis são:

  • Operador =
  • Operador[]
  • Início e fim do iterador
  • Vazio
  • Tamanho da capacidade
  • Para uma pesquisa, localize e conte.
  • Inserir e excluir

A lista completa dos métodos de um mapa não ordenado é mostrada abaixo:

No():

Este método de mapa não ordenado c++ retorna uma referência ao valor com o elemento especificado como o chave k .

Começar():

Ele fornece um valor de retorno que é um iterador apontando para a primeira entrada no contêiner do mapa não ordenado.

ordenação por inserção java

Fim():

O bucket de contêiner de mapa não ordenado retorna um iterador apontando para o local após o elemento final ().

Balde():

Ele retorna o número do bucket na contagem de buckets do mapa onde o elemento com chave k está localizado.

Balde_contagem()

O número total de buckets do mapa não ordenado é contabilizado usando a função de contagem de bucket. Pode ser chamado sem passar nenhum parâmetro.

Tamanho do balde

Fornece a contagem de elementos do mapa não ordenado para cada balde () .

tornando um script de shell executável

Contar()

Fornece a contagem de elementos do mapa não ordenado para cada balde () o número de elementos em um mapa não ordenado com o intervalo igual de chave especificado deve ser contado.

intervalo_equal()

Ele retorna os limites de um intervalo com todos os itens do contêiner e uma chave que compara com k .

Encontrar()

Fornece um iterador para o elemento vazio.

Posição ()

exemplos de sistema operacional

Determina se o contêiner do mapa não ordenado está vazio.

Apagar()

Os elementos no contêiner do mapa não ordenado podem ser excluídos usando o comando apagar() função.

Embora as funções para visualizar o tamanho do bucket interno, a contagem do bucket, a função hash usada e várias políticas de hash também sejam fornecidas pelo biblioteca c++11 , eles são menos úteis em aplicações práticas. Usando o iterador, podemos percorrer cada elemento do mapa não ordenado.

Exemplo:

 #include #include using namespace std; int main() { // when we will declare a umap it must be of type and here the key will be of string type and the mapped value of double in nature unordered_mapumap = { //in this we will insert the element in map directly {&apos;one&apos;, 1}, {&apos;two&apos;, 2}, {&apos;three&apos;, 3} }; // here wi will insert the values by the help of the [] operator umap[&apos;the value of pi&apos;] = 3.14; umap[&apos;the value of root2&apos;] = 1.414; umap[&apos;the value ofroot3&apos;] = 1.732; umap[&apos;the value oflog10&apos;] = 2.302; umap[&apos;the value ofloge&apos;] = 1.0; // inserting value by insert function umap.insert(make_pair(&apos;e&apos;, 2.718)); string key = &apos;the value of pi&apos;; // if key not found in map iterator // to end is returned if (umap.find(key) == umap.end()) cout&lt;&lt; key &lt;<\' cannot retrieved

\'; if key found then iterator to that is returned else cout<< \'retrieved \'<< << \'

\'; ; (umap.find(key)="=" umap.end()) <<\' retrieved
\'; \'found <<endl; now we will iterate over all value of umap unordered_map::iterator itr; \'
the entire elements : 
\'; for (itr="umap.begin();" itr !="umap.end();" itr++) { cout<first \' <second } return 0; < pre> <p> <strong>Output</strong> </p> <pre> Retrieved the value of pi Lambda value cannot retrieved The entire elements : E 2.718 The value ofloge 1 The value oflog10 2.302 The value of root2 1.414 The value ofroot3 1.732 The value of pi 3.14 Two 2 Three 3 One 1 </pre> <h3>Example:</h3> <pre> // It is a c++ program to find rhefreqency of it ,in this we will use of unordered_map of every word #include using namespace std; void printfrequencies(const string &amp;str) { unordered_mapwordfreq; stringstream ss(str); string word; while (ss&gt;&gt; word) wordfreq[word]++; unordered_map:: iterator q; for (q = wordfreq.begin(); q != wordfreq.end(); q++) cout&lt;&lt; &apos;(&apos; <first << \', \' <second \')
\'; } int main() { string str="java t points questions " \'learn programs\'; printfrequencies(str); return 0; < pre> <p> <strong>Output</strong> </p> <pre> (programs, 1) (learn, 1) (questions, 1) (t, 1) (points, 1) (java, 1) </pre> <hr></first></pre></\'>

Exemplo:

 // It is a c++ program to find rhefreqency of it ,in this we will use of unordered_map of every word #include using namespace std; void printfrequencies(const string &amp;str) { unordered_mapwordfreq; stringstream ss(str); string word; while (ss&gt;&gt; word) wordfreq[word]++; unordered_map:: iterator q; for (q = wordfreq.begin(); q != wordfreq.end(); q++) cout&lt;&lt; &apos;(&apos; <first << \', \' <second \')
\'; } int main() { string str="java t points questions " \'learn programs\'; printfrequencies(str); return 0; < pre> <p> <strong>Output</strong> </p> <pre> (programs, 1) (learn, 1) (questions, 1) (t, 1) (points, 1) (java, 1) </pre> <hr></first>