溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

容器迭代器使用技巧

發(fā)布時(shí)間:2024-09-10 12:25:53 來(lái)源:億速云 閱讀:79 作者:小樊 欄目:編程語(yǔ)言

容器迭代器是一種用于遍歷容器中元素的對(duì)象

  1. 使用auto關(guān)鍵字簡(jiǎn)化迭代器類型:
std::vector<int> vec = {1, 2, 3, 4, 5};
for (auto it = vec.begin(); it != vec.end(); ++it) {
    std::cout << *it << " ";
}
  1. 使用范圍for循環(huán)(C++11及更高版本):
std::vector<int> vec = {1, 2, 3, 4, 5};
for (const auto &element : vec) {
    std::cout<< element << " ";
}
  1. 使用反向迭代器:
std::vector<int> vec = {1, 2, 3, 4, 5};
for (auto it = vec.rbegin(); it != vec.rend(); ++it) {
    std::cout << *it << " ";
}
  1. 使用std::next和std::prev移動(dòng)迭代器:
std::vector<int> vec = {1, 2, 3, 4, 5};
auto it = vec.begin();
std::cout << *std::next(it)<< std::endl; // 輸出2
std::cout << *std::prev(std::next(it, 2))<< std::endl; // 輸出1
  1. 使用std::distance計(jì)算兩個(gè)迭代器之間的距離:
std::vector<int> vec = {1, 2, 3, 4, 5};
auto it1 = vec.begin();
auto it2 = vec.begin() + 2;
std::cout<< std::distance(it1, it2)<< std::endl; // 輸出2
  1. 使用std::advance移動(dòng)迭代器:
std::vector<int> vec = {1, 2, 3, 4, 5};
auto it = vec.begin();
std::advance(it, 2);
std::cout << *it<< std::endl; // 輸出3
  1. 在遍歷過(guò)程中刪除元素:
std::list<int> lst = {1, 2, 3, 4, 5};
for (auto it = lst.begin(); it != lst.end();) {
    if (*it % 2 == 0) {
        it = lst.erase(it);
    } else {
        ++it;
    }
}
  1. 使用std::find查找元素:
std::vector<int> vec = {1, 2, 3, 4, 5};
auto it = std::find(vec.begin(), vec.end(), 3);
if (it != vec.end()) {
    std::cout << "Found: " << *it<< std::endl;
} else {
    std::cout << "Not found"<< std::endl;
}
  1. 使用std::lower_bound、std::upper_bound和std::equal_range查找元素:
std::set<int> s = {1, 2, 3, 4, 5};
auto lb = std::lower_bound(s.begin(), s.end(), 3);
auto ub = std::upper_bound(s.begin(), s.end(), 3);
auto er = std::equal_range(s.begin(), s.end(), 3);
  1. 使用std::for_each應(yīng)用函數(shù)于容器中的每個(gè)元素:
std::vector<int> vec = {1, 2, 3, 4, 5};
std::for_each(vec.begin(), vec.end(), [](int x) { std::cout << x << " "; });

這些技巧可以幫助你更有效地使用容器迭代器。請(qǐng)注意,這里給出的示例主要針對(duì)C++標(biāo)準(zhǔn)庫(kù)容器,但許多技巧也適用于其他容器類型。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

c++
AI