std::list::crbegin
#include <list>
Trả về một const_reverse_iterator trỏ đến phần tử cuối cùng của std::list. crbegin() là viết tắt của "constant reverse begin".
const_reverse_iterator crbegin() const noexcept;
Tham số
Không có tham số
Giá trị trả về
- Trả về một const_reverse_iterator trỏ đến phần tử cuối cùng của std::list. const_reverse_iterator chỉ cho phép đọc giá trị, không cho phép thay đổi.
Đặc điểm
- Duyệt ngược và chỉ đọc:
crbegin()cho phép bạn duyệt các phần tử theo thứ tự đảo ngược, bắt đầu từ phần tử cuối cùng, nhưng chỉ được phép đọc, không được sửa đổi giá trị. - noexcept:
crbegin()được đánh dấu lànoexcept, nghĩa là nó được đảm bảo không ném ra ngoại lệ nào. - Kết hợp với
crend():crbegin()thường được sử dụng cùng vớicrend()để duyệt ngược qua toàn bộ std::list.crend()trả về const_reverse_iterator trỏ đến phần tử "past-the-end" ở phía trước phần tử đầu tiên (theo chiều duyệt thông thường). - Phân biệt với
rbegin():rbegin()trả về reverse_iterator (có thể đọc và ghi), trong khicrbegin()trả về const_reverse_iterator (chỉ đọc). - Không thay đổi std::list: Gọi
crbegin()không làm thay đổi nội dung của std::list. - Độ phức tạp:
O(1)- thời gian hằng số.
Ví dụ
#include <iostream>
#include <list>
#include <algorithm>
int main() {
std::list<int> mylist = {1, 2, 3, 4, 5};
// Tìm giá trị lớn nhất sử dụng crbegin() và crend()
auto it = std::max_element(mylist.crbegin(), mylist.crend());
if (it != mylist.crend()) {
std::cout << "Largest element: " << *it << std::endl; // Output: Largest element: 5
}
return 0;
}
Các hàm liên quan
| begin | Trả về một iterator trỏ đến phần tử đầu tiên trong list |
| crend | Trả về một const_reverse_iterator trỏ đến phần tử trước phần tử đầu tiên của std::list |
| rbegin | Trả về một reverse_iterator trỏ đến phần tử cuối cùng của std::list |