lower_bound和 upper_bound 用法(STL)
lower_bound和 upper_bound的頭文件是#include<algorithm>
lower_bound
返回第一個大于等于 x 的數的地址/迭代器
upper_bound
返回第一個大于 x 的數的地址/迭代器
————————————————————————————————————————————————————————
兩者都是類似binary-search(二分)來查找 ,用法分為兩部分說,
數組
這里就拿lower_bound舉例,upper_bound用法一樣
auto it = lower_bound(vec.begin(),vec.end(),x)可以看出就三個參數,在前閉后開區間 [vec.begin(),vec.end()) 進行二分查找,返回大于或等于 x 的第一個元素位置。如果所有元素都小于 x ,則返回 vec.end() 的位置
如果要得到最后大于等于 x 的元素下標,只需要減去初位置就可以了;
int pos = lower_bound(vec.begin(),vec.end(),x) - vec.begin();測試代碼:
#include<iostream> #include<vector> #include<algorithm> using namespace std;int main() {vector<int> vec(5);int num = 10;for (int i = 0; i < 5; ++i) vec[i] = num++;vector<int>::iterator it = lower_bound(vec.begin(), vec.end(), 11);cout << "大于等于11的數為:" << *it << endl;int pos = lower_bound(vec.begin(), vec.end(), 11) - vec.begin();cout << "該數的下標為:" << pos << endl;return 0; }map/set
這里用法有點不同,這里拿set舉例
相對于數組以算法的形式使用,
set 輸入時已經建好樹(不需要algorithm頭文件), 而algorithm要多一個類似建樹的過程
s所以 set 有 s.lower_bound(x) 算法,所以使用該函數肯定 set 快一點
作用:
lower_bound
二分查找一個有序數列,返回第一個大于等于x的數,如果沒找到,返回末尾的迭代器位置
upper_bound
二分查找一個有序數列,返回第一個大于等于x的數,如果沒找到,返回末尾的迭代器位置
可以發現起始功能還是一樣的,但是參數有些不同,
set::lower_bound(x):返回set中第一個大于或等于 x 的迭代器指針set::upper_bound(x):返回set中第一個大于 x 的迭代器指針可以看出,只需要比較的 x 就可以了;
測試代碼:
總結
以上是生活随笔為你收集整理的lower_bound和 upper_bound 用法(STL)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: ++i 和 i++ 效率分析(C++)
- 下一篇: 内建函数对象(STL)