【C++】algorithm具体操作记录
生活随笔
收集整理的這篇文章主要介紹了
【C++】algorithm具体操作记录
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
find尋找特定元素位置
int main(char argc, int* argv[]) {vector<int> intVec = { 0,1,1,1,1,2,3,4,5,6,7,8,9 };if (pos != intVec.end())cout << "The value 5 exists,and its position is " <<distance(intVec.begin(), pos) + 1 << endl;elsecout << "The value 4 not found!" << endl;getchar();return 0;
}
std::unique 與erase組合:去除重復元素
unique去除返回迭代器位置(首先需要sort 數組排序)
vector<string> wordVec = { "the","quick","red","fox","jnmp","slow","over","the","red" };std::sort(wordVec.begin(), wordVec.end());//fox jnmp over quick red red slow the theauto end_unique =std::unique(wordVec.begin(), wordVec.end());wordVec.erase(end_unique, wordVec.end());//fox jnmp over quick red slow the// end_unique位置指向第一個the末尾
謂詞:可調用表達式,返回解結果可作為條件的值
stable_sort 穩定排序算法
- 一元謂詞 : 接受單一的參數
- 二元謂詞 : 接受2個參數
bool isShorter(const string& s1, const string& s2) {return s1.size() < s2.size();
}int main(char argc, int* argv[]) {vector<string> wordVec = { "the","quick","red","fox","jnmp","slow","over","the","red" };std::stable_sort(wordVec.begin(), wordVec.end(), isShorter);//the red fox the red jnmp slow over quickreturn 0;
}
可調用對象 :4種
函數 函數指針 重載了函數調用的類 lamda表達式
- “-”
- “+”
- “*”
- “+”
總結
以上是生活随笔為你收集整理的【C++】algorithm具体操作记录的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 关于电视剧。
- 下一篇: 【C++】关联容器学习记录