vector 进阶
Posted 于光远
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了vector 进阶相关的知识,希望对你有一定的参考价值。
http://classfoo.com/ccby/article/jnevK
#include <iostream> #include <vector> #include <algorithm> // sort, max_element, random_shuffle, remove_if, lower_bound #include <functional> // greater, bind2nd // 用在此处是为了方便简洁, 在实际编程中慎用 using namespace std; int main() { int arr[4] = { 1, 2, 3, 4 }; // 用上述数组初始化向量 vector<int> foo(arr, arr + 4); // 插入更多的元素 foo.push_back(5); foo.push_back(6); foo.push_back(7); foo.push_back(8); // 此时的向量内容为 {1, 2, 3, 4, 5, 6, 7, 8} // 随机移动元素 random_shuffle(foo.begin(), foo.end()); // 定位最大的元素, O(n) vector<int>::const_iterator largest = max_element(foo.begin(), foo.end()); cout << "当前最大元素是: " << *largest << "\\n"; cout << "它的索引位置是: " << largest - foo.begin() << "\\n"; // 排序元素 sort(foo.begin(), foo.end()); // 用二分查找法找出向量中值为5的元素 vector<int>::const_iterator five = lower_bound(foo.begin(), foo.end(), 5); cout << "值为5的元素的索引位置是: " << five - foo.begin() << "\\n"; // 删除所有值大于4的元素 foo.erase(remove_if(foo.begin(), foo.end(), bind2nd(greater<int>(), 4)), foo.end()); // 打印所有剩余元素的值 for (vector<int>::const_iterator it = foo.begin(); it != foo.end(); ++it) { cout << *it << " "; } cout << "\\n"; return 0; }
对象
#include <iostream> #include <vector> #include <string> #include <algorithm> #include <functional> #include <sstream> namespace ClassFoo{ using namespace std; class Person { private: std::string name; static int n; public: Person() { std::stringstream ss; std::string snum; ss << n++; ss >> snum; name = "foo" + snum; } void print() const { std::cout << name << std::endl; } void printWithPrefix(std::string prefix) const { std::cout << prefix << name << std::endl; } }; int Person::n = 0; void foo(const std::vector<Person>& coll) { // 对每个元素对象调用成员函数 print() for_each(coll.begin(), coll.end(), mem_fun_ref(&Person::print)); // 对每个元素对象调用成员函数 printWithPrefix() // - "person: " 作为参数传递给成员函数 for_each(coll.begin(), coll.end(), bind2nd(mem_fun_ref(&Person::printWithPrefix), "person: ")); } void ptrfoo(const std::vector<Person*>& coll) { // 对每个指针指向的元素对象调用成员函数 print() for_each(coll.begin(), coll.end(), mem_fun(&Person::print)); // 对每个指针指向的元素对象调用成员函数 printWithPrefix() // - "person: " 作为参数传递给成员函数 for_each(coll.begin(), coll.end(), bind2nd(mem_fun(&Person::printWithPrefix), "person: ")); } } int main() { std::cout << "当向量的元素是对象时:" << std::endl; std::vector<ClassFoo::Person> coll(5); ClassFoo::foo(coll); std::cout << "当向量的元素是指向对象的指针时:" << std::endl; std::vector<ClassFoo::Person*> coll2; coll2.push_back(new ClassFoo::Person); coll2.push_back(new ClassFoo::Person); coll2.push_back(new ClassFoo::Person); coll2.push_back(new ClassFoo::Person); coll2.push_back(new ClassFoo::Person); ClassFoo::ptrfoo(coll2); }
以上是关于vector 进阶的主要内容,如果未能解决你的问题,请参考以下文章
我的C语言学习进阶之旅解决 Visual Studio 2019 报错:错误 C4996 ‘fscanf‘: This function or variable may be unsafe.(代码片段
我的C语言学习进阶之旅解决 Visual Studio 2019 报错:错误 C4996 ‘fscanf‘: This function or variable may be unsafe.(代码片段
我的Android进阶之旅关于Android平台获取文件的mime类型:为啥不传小写后缀名就获取不到mimeType?为啥android 4.4系统获取不到webp格式的mimeType呢?(代码片段
我的Android进阶之旅关于Android平台获取文件的mime类型:为啥不传小写后缀名就获取不到mimeType?为啥android 4.4系统获取不到webp格式的mimeType呢?(代码片段