C++ List::rbegin() 函式



C++ 的std::list::rbegin()函式用於獲取一個反向迭代器,指向反轉列表的第一個元素。它對應於非反轉列表的最後一個元素。

在 C++ 中,迭代器是一個物件,用於指向 STL(標準模板庫)容器的記憶體地址。我們使用(*)符號來檢索迭代器指向的當前位置的元素。(*)符號在 C++ 中稱為星號運算子。

如果列表為空,則返回的迭代器等於 rend()。

語法

以下是 C++ std::list::rbegin() 函式的語法 -

reverse_iterator rbegin();

引數

  • 它不接受任何引數。

返回值

此函式返回一個反向迭代器。

示例 1

在以下程式中,我們使用 C++ std::list::rbegin() 函式來獲取一個反向迭代器,指向當前反轉列表 {10, 20, 30, 40, 50} 的第一個元素。

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

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

輸出

以下是上述程式的輸出 -

List elements are: 10 20 30 40 50 
The iterator of the last element: 50

示例 2

除了 int 型別的列表元素外,您還可以檢索任何其他型別的列表元素的迭代器,例如 char 和 string 列表內容。

以下是 C++ std::list::rbegin() 函式的另一個示例。在這裡,我們建立一個名為 vowels 的列表(型別為 char),其值為 {'a', 'e', 'i', 'o', 'u'}。然後使用 rbegin() 函式,我們嘗試獲取一個反向迭代器,指向當前反轉列表的第一個元素。

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

int main() {
   //create a list
   list<char> vowels = {'a', 'e', 'i', 'o', 'u'};
   cout<<"List elements are: ";
   for(char v : vowels) {
      cout<<v<<" ";
   }
   auto ri = vowels.rbegin();
   cout<<"\nThe iterator of the last element: ";
   cout<<*ri;
}

輸出

這將生成以下輸出 -

List elements are: a e i o u 
The iterator of the last element: u

示例 3

如果列表型別是字串。

在此示例中,我們建立一個名為 fname 的列表(型別為 string),其值為 {"Rohan", "Reema", "Geeta", "Seema"}。然後,使用 rbegin() 函式,我們嘗試獲取一個反向迭代器,指向當前反轉列表的第一個元素。

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

int main() {
   //create a list
   list<string> names = {"Rohan", "Reema", "Geeta", "Seema"};
   cout<<"List elements are: ";
   for(string s : names) {
      cout<<s<<" ";
   }
   auto ri = names.rbegin();
   cout<<"\nThe iterator of the last element: ";
   cout<<*ri;
}

輸出

上述程式產生以下輸出 -

List elements are: Rohan Reema Geeta Seema 
The iterator of the last element: Seema

示例 4

使用 for 迴圈以及 rbegin() 函式來檢索容器元素的迭代器。

在此示例中,我們使用 rbegin() 函式以及 for 迴圈來遍歷當前容器 {1, 2, 3, ,4 ,5} 並以反向順序檢索容器中所有元素的迭代器。

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

int main() {
   //create a list
   list<int> num_list = {1, 2, 3, 4 ,5};
   cout<<"List elements are: ";
   for(int n : num_list) {
      cout<<n<<" ";
   }
   cout<<"\nA reverse iterator of an elements are : ";
   for(auto i = num_list.rbegin(); i!=num_list.rend(); i++) {
      cout<<*i<<" ";
   }
}

輸出

執行上述程式後,將產生以下輸出 -

List elements are: 1 2 3 4 5 
A reverse iterator of an elements are : 5 4 3 2 1 
廣告

© . All rights reserved.