std::multimap::end
#include <map>
iterator end() noexcept;
const_iterator end() const noexcept;
Trả về một iterator trỏ đến vị trí sau phần tử cuối cùng trong std::multimap. Vị trí này, thường được gọi là "past-the-end", không phải là một phần tử thực sự trong multimap, mà là một vị trí đặc biệt dùng để đánh dấu kết thúc của multimap.
Tham số
Không có tham số
Giá trị trả về
iterator
(phiên bản không const): Trả về một iterator có thể đọc và ghi, trỏ đến vị trí sau phần tử cuối cùng trong std::multimap.const_iterator
(phiên bản const): Trả về một iterator chỉ đọc, trỏ đến vị trí sau phần tử cuối cùng trong std::multimap. Phiên bản này được sử dụng khi std::multimap là một đối tượngconst
.
Đặc điểm
- Vị trí "past-the-end":
end()
không trỏ đến một phần tử thực sự trong std::multimap, mà là một vị trí sau phần tử cuối cùng. - Không thể dereference: Bạn không thể dereference (sử dụng toán tử
*
hoặc->
) iterator trả về bởiend()
vì nó không trỏ đến một phần tử hợp lệ. - Đánh dấu kết thúc multimap:
end()
được sử dụng để đánh dấu điểm kết thúc của std::multimap trong các vòng lặp và thuật toán. - noexcept: Cả hai phiên bản của
end()
đều được đánh dấu lànoexcept
, nghĩa là chúng được đảm bảo không ném ra ngoại lệ nào. - Phân biệt với
begin()
:begin()
trỏ đến phần tử đầu tiên, trong khiend()
trỏ đến vị trí sau phần tử cuối cùng. - std::multimap rỗng: Nếu std::multimap rỗng thì
end()
sẽ trả về giá trị giốngbegin()
. - Không làm thay đổi map: Gọi
end()
không làm thay đổi nội dung hay trạng thái của std::multimap. - Độ phức tạp:
O(1)
- thời gian hằng số.
Ví dụ
#include <iostream>
#include <map>
int main() {
std::multimap<std::string, int> mymultimap = {
{"apple", 1},
{"banana", 2},
{"orange", 3},
{"apple", 4}
};
// Duyệt multimap sử dụng begin() và end()
std::cout << "mymultimap elements:\n";
for (auto it = mymultimap.begin(); it != mymultimap.end(); ++it) {
std::cout << it->first << ": " << it->second << '\n';
}
// Output:
// mymultimap elements:
// apple: 1
// apple: 4
// banana: 2
// orange: 3
return 0;
}
sử dụng begin() và end() để kiểm tra multimap rỗng
#include <iostream>
#include <map>
int main() {
std::multimap<int, int> mymultimap;
if (mymultimap.begin() == mymultimap.end()) {
std::cout << "mymultimap is empty\n"; // Output: mymultimap is empty
}
return 0;
}
Các hàm liên quan
begin | Trả về một iterator trỏ đến phần tử đầu tiên trong std::multimap |
rbegin | Trả về một reverse_iterator trỏ đến phần tử cuối cùng trong std::multimap |
rend | Trả về một reverse_iterator trỏ đến phần tử trước phần tử đầu tiên của std::multimap |