C ++
 Computer >> コンピューター >  >> プログラミング >> C ++

C ++ STLでcrbegin()およびcrend()関数をマップします


この記事では、C++STLでのmap::crbegin()およびmap ::crend()関数の動作、構文、および例について説明します。

C ++ STLのマップとは何ですか?

マップは連想コンテナであり、キー値とマップされた値の組み合わせによって形成された要素を特定の順序で格納するのを容易にします。マップコンテナでは、データは常に関連するキーを使用して内部的に並べ替えられます。マップコンテナの値には、一意のキーからアクセスします。

map ::cbegin()とは何ですか?

map ::crbegin()関数は、C ++ STLに組み込まれている関数であり、 ヘッダーファイルで定義されています。 crbegin()は、constant reverse beginを意味します。これは、constant beginであったcbeginの逆を意味します。つまり、関数crbegin()は、関数に関連付けられたマップコンテナの最後の要素を指すイテレータを返します。このイテレータを使用してマップを変更することはできません。これは、設定されたコンテナをトラバースするために使用できます。

構文

Map_name.crbegin();

パラメータ

この関数はパラメータを受け入れません。

戻り値

この関数は、マップコンテナの最後の要素を指しているイテレータを返します。

入力

map<char, int> newmap;
newmap[‘a’] = 1;
newmap[‘b’] = 2;
newmap[‘c’] = 3;
newmap.crbegin();

出力

c:3

map ::crbegin

#include <bits/stdc++.h>
using namespace std;
int main() {
   map<int, int> TP_Map;
   TP_Map.insert({3, 50});
   TP_Map.insert({2, 30});
   TP_Map.insert({1, 10});
   TP_Map.insert({4, 70});
   //using map::crbegin to fetch first last element
   auto temp = TP_Map.crbegin();
   cout<<"First element is: "<<temp->first << " -> " << temp->second;
   cout<<"\nTP Map is : \n";
   cout << "MAP_KEY\tMAP_ELEMENT\n";
   for (auto i = TP_Map.crbegin(); i!= TP_Map.crend(); i++) {
      cout << i->first << "\t" << i->second << endl;
   }
   return 0;
}

出力

First element is: 4 -> 70
TP Map is:
MAP_KEY    MAP_ELEMENT
4             70
3             50
2             30
1             10

map ::crend()とは何ですか?

map ::crend()関数は、C ++ STLに組み込まれている関数であり、 ヘッダーファイルで定義されています。 crend()は、定数逆端イテレータを意味します。これは、定数終了イテレータであったcendの逆であることを意味します。つまり、関数crend()は、関連付けられたマップコンテナの最初の位置の直前の位置を指しているイテレータを返します。関数で。このイテレータを使用してマップを変更することはできません。これは、マップコンテナをトラバースするために使用できます。

構文

newmap.crend();

パラメータ

この関数はパラメータを受け入れません。

戻り値

関連するマップコンテナの前の最初の要素を指すイテレータを返します。

入力

map<char, int> newmap;
newmap[‘a’] = 1;
newmap[‘b’] = 2;
newmap[‘c’] = 3;
newmap.crend();

出力

error

map ::crend

#include <bits/stdc++.h>
using namespace std;
int main() {
   map<int, int> TP_Map;
   TP_Map.insert({3, 50});
   TP_Map.insert({2, 30});
   TP_Map.insert({1, 10});
   TP_Map.insert({4, 70});
   cout<<"\nTP Map is : \n";
   cout << "MAP_KEY\tMAP_ELEMENT\n";
   for (auto i = TP_Map.crbegin(); i!= TP_Map.crend(); i++) {
      cout << i->first << "\t" << i->second << endl;
   }
   return 0;
}

出力

TP Map is:
MAP_KEY    MAP_ELEMENT
4             70
3             50
2             30
1             10

  1. C++STLのArray::crbegin()とarray ::crend()?

    ここでは、C ++ STLの配列のcrbegin()関数とcrend()関数を確認します。 array ::crbegin()関数は、逆イテレータを取得するために使用されます。コンテナの最後の要素を指す定数逆イテレータを返します。この関数はパラメータを取りません。 array ::crend()関数はcrbegin()の逆です。これにより、逆イテレータの最後の要素を指しているイテレータが返されます。 より良いアイデアを得るために、いくつかのコード例を見てみましょう。 例 #include<iostream> #include<array> using namesp

  2. C++STLのマップおよびマルチマップの降順

    一般に、マップおよびマルチマップマップのデフォルトの動作は、要素を昇順で格納することです。ただし、大きい関数を使用すると、要素を降順で格納できます。 降順の地図: 関数はここで使用されます- m ::find() –見つかった場合は、マップ内のキー値「b」を持つ要素にイテレータを返します。それ以外の場合は、終了するイテレータを返します。 m ::Erase() –マップからキー値を削除します。 m ::equal_range() –ペアのイテレータを返します。ペアは、キーと同等のキーを持つコンテナ内のすべての要素を含む範囲の境界を指します。 m insert