C++ List::rend() 函数



C++ 的std::list::rend()函数用于检索一个反向迭代器,该迭代器指向反转列表的最后一个元素之后的元素。

此函数对应于非反转列表的第一个元素之前的元素。此列表中的元素充当占位符,尝试访问它会导致未定义的行为。在 C++ 中,迭代器用于指向 STL(标准模板库)容器的内存地址。

rend() 函数类似于 crend() 函数,其中 crend() 函数返回一个指向反转列表的最后一个元素之后的元素的常量反向迭代器,而 rend() 函数返回一个指向反转列表的最后一个元素之后的元素的反向迭代器。

语法

以下是 C++ std::list::rend() 函数的语法:

const_reverse_iterator rend();

参数

  • 它不接受任何参数。

返回值

此函数返回一个反向迭代器,该迭代器指向反转列表的最后一个元素之后的元素。

示例 1

在下面的程序中,我们使用 C++ std::list::rend() 函数来检索一个反向迭代器,该迭代器指向当前列表 {10, 20, 30, 40} 的最后一个元素之后的元素。

#include<iostream>
#include<list>
using namespace std;

int main() {
   //create a list
   list<int> num_list = {10, 20, 30, 40};
   cout<<"List elements are: ";
   for(int n : num_list) {
      cout<<n<<" ";
   }
   auto it = num_list.rend();
   cout<<"\nA reverse iterator of the last element: ";
   cout<<*it;
}

输出

以下是上述程序的输出:

List elements are: 10 20 30 40 
A constant reverse iterator of the last element: 4

示例 2

除了 int 类型的列表元素外,您还可以检索任何其他类型的列表元素(如 char 和 string 列表内容)的迭代器。

以下是 C++ std::list::rend() 函数的另一个示例。在这里,我们创建一个名为 symbols 的列表(类型为 char),其值为 {'@', '#', '$', '%', '&', '*'}. 然后使用 rend() 函数,我们尝试检索一个反向迭代器,该迭代器指向反转列表的最后一个元素之后。

#include<iostream>
#include<list>
using namespace std;

int main() {
   //create a list
   list<char> symbols  = {'@', '#', '$', '%', '&', '*'};
   cout<<"List elements are: ";
   for(char v : symbols) {
      cout<<v<<" ";
   }
   auto it = symbols.rend();
   cout<<"\nA reverse iterator of the last element: ";
   cout<<*it;
}

输出

这将生成以下输出:

List elements are: @ # $ % & * 
A reverse iterator of the last element: 

示例 3

如果列表类型是字符串。

在此示例中,我们创建一个名为 names 的列表(类型为 string),其值为 {"Mukesh", "Rahul", "Mohan", "Shavita"}。然后,使用 rend() 函数,我们尝试检索一个反向迭代器,该迭代器指向反转列表的最后一个元素之后。

#include<iostream>
#include<list>
using namespace std;

int main() {
   //create a list
   list<string> names = {"Mukesh", "Rahul", "Mohan", "Shavita"};
   cout<<"List elements are: ";
   for(string s : names ) {
      cout<<s<<" ";
   }
   auto it = names.rend();
   cout<<"\nA reverse iterator of the last element: ";
   cout<<*it;
}

输出

上述程序产生以下输出:

List elements are: Mukesh Rahul Mohan Shavita 
A reverse iterator of the last element: 
Segmentation fault

示例 4

使用 for 循环以及 rend() 函数来检索反转列表的反向迭代器。

在此示例中,我们使用 rend() 函数以及 for 循环来遍历当前容器 {1, 2, 3, 4 ,5, 6, 7, 8, 9, 10} 并检索反转列表所有元素的反向迭代器。

#include<iostream>
#include<list>
using namespace std;

int main() {
   //create a list
   list<int> num_list = {1, 2, 3, 4 ,5, 6, 7, 8, 9, 10} ;
   cout<<"List elements are: ";
   for(int n : num_list) {
      cout<<n<<" ";
   }
   cout<<"\nThe reverse iterator of an elements are : ";
   for (auto it = num_list.crbegin(); it != num_list.rend(); it++) {
      cout<<*it<<" ";
   }
}

输出

执行上述程序后,它将产生以下输出:

List elements are: 1 2 3 4 5 6 7 8 9 10 
The reverse iterator of an elements are : 10 9 8 7 6 5 4 3 2 1 
广告