当前位置: 首页>>代码示例 >>用法及示例精选 >>正文


C++ multiset crbegin()用法及代码示例


C++ multiset crbegin() 函数用于返回引用 multiset 容器中最后一个元素的常量反向迭代器。

multiset 的常量反向迭代器以相反的方向移动并递增它,直到它到达 multiset 容器的开头(第一个元素)并指向常量元素。

用法

const_reverse_iterator crbegin() const noexcept;  	      //since C++ 11

参数

返回值

它返回一个指向多重集最后一个元素的常量反向迭代器。

参数

返回值

crbegin() 函数返回一个常量反向迭代器,指向 multimap 的最后一个元素。

复杂度

恒定。

迭代器有效性

没有变化。

数据竞争

容器被访问。

同时访问多集容器的元素是安全的。

异常安全

这个函数从不抛出异常。

例子1

让我们看看 crbegin() 函数的简单示例:

#include <iostream>
#include <set>

using namespace std;

int main ()
{
  multiset<int> mymultiset = {40,20,30,10,30,10};

  cout << "mymultiset in reverse order:";
  for (auto rit=mymultiset.crbegin(); rit != mymultiset.crend(); ++rit)
    cout << ' ' << *rit;

  cout << '\n';

  return 0;
}

输出:

mymultiset in reverse order:40 30 30 20 10 10

在上面的例子中,crbegin() 函数用于返回一个指向 mymultiset 多集中最后一个元素的常量反向迭代器。

由于多重集以键的排序顺序存储元素,因此迭代多重集将导致上述顺序,即键的排序顺序。

例子2

让我们看一个使用 while 循环以相反顺序迭代多重集的简单示例:

#include <iostream>
#include <set>
#include <string>
#include <iterator>

using namespace std;
 
int main() {
 
	// Creating & Initializing a multiset of String & Ints
	multiset<string> multisetEx = {"bbb", "ccc", "aaa", "bbb"};

	// Create a multiset iterator and point to the end of multiset
	 multiset<string>::const_reverse_iterator it = multisetEx.crbegin();
 
	// Iterate over the multiset using Iterator till beginning.
	while (it != multisetEx.crend()) {
		// Accessing KEY from element pointed by it.
		string word = *it;
 
		cout << word << endl;
 
		// Increment the Iterator to point to next entry
		it++;
	}
	return 0;
}

输出:

ccc
bbb
bbb
aaa

在上面的例子中,我们以相反的顺序在多重集上使用 while 循环到 const_iterate 和 crbegin() 函数初始化多重集的最后一个元素。

由于多重集以键的排序顺序存储元素,因此迭代多重集将导致上述顺序,即键的排序顺序。

例子3

让我们看一个简单的例子来获取反向多重集的第一个元素:

#include <iostream>
#include <string>
#include <set>

using namespace std;

int main ()
{
  multiset<int> s1 = {20,40,10,30, 20};
          
    auto ite = s1.crbegin();
 
    cout << "The first element of the reversed multiset s1 is:";
    cout << *ite;

  return 0;
  }

输出:

The first element of the reversed multiset s1 is:40

在上面的例子中,crbegin() 函数返回反向多重集 s1 的第一个元素,即 40。

示例 4

让我们看一个简单的例子来排序和计算最高分:

#include <iostream>
#include <string>
#include <set>

using namespace std;

int main ()
{
  multiset<int> marks = {400, 220, 250, 250, 365, 220};

   cout << "Marks" << '\n';
   cout<<"______________________\n";
   
  multiset<int>::const_reverse_iterator rit;
  for (rit=marks.crbegin(); rit!=marks.crend(); ++rit)
    cout << *rit<< '\n';

    auto ite = marks.crbegin();
 
    cout << "\nHighest Marks is:"<< *ite<<" \n";

  return 0;
  }

输出:

Marks
______________________
400
365
250
250
220
220

Highest Marks is:400 

在上面的示例中,实现了多集 'marks',其中该多集的元素存储为键。函数 crbegin() 使我们能够利用多重集中的自动排序,并让我们识别最高分。





相关用法


注:本文由纯净天空筛选整理自 C++ multiset crbegin()。非经特殊声明,原始代码版权归原作者所有,本译文未经允许或授权,请勿转载或复制。