演讲比赛流程管理案例

January 22, 2022 · 0 min · Rick Cui

常用算法

一、常用遍历算法 1. for_each 2. transform 搬运的目标容器必须要提前开辟空间(resize 而不是 reserve),否则无法正常搬运 int main() { vector<int> v; for(int i = 0; i < 10; ++i){ v.push_back(i); } vector<int> v1; v1.resize(v.size()); // 要用 resize, 不能用 reserve transform(v.begin(), v.end(), v1.begin(), [](int v){ return v * 2;}); for_each(v1.begin(), v1.end(), [](int v){ cout << v << " "; }); cout << endl; return 0; } 二、常用查找算法 1. find 2. find_if 3. adjacent_find 4. binary_search 无序序列不可用 5....

January 22, 2022 · 2 min · Rick Cui

内建函数对象 functional

算术仿函数 template<class T> T plus<T> //加法仿函数 template<class T> T minus<T> //减法仿函数 template<class T> T multiplies<T> //乘法仿函数 template<class T> T divides<T> //除法仿函数 template<class T> T modulus<T> //取模仿函数 template<class T> T negate<T> //取反仿函数 一元谓词 关系仿函数 template<class T> bool equal_to<T> //等于 template<class T> bool not_equal_to<T> //不等于 template<class T> bool greater<T> //大于 template<class T> bool greater_equal<T> //大于等于 template<class T> bool less<T> //小于 template<class T> bool less_equal<T> //小于等于 逻辑仿函数 template<class T> bool logical_and<T> //逻辑与 template<class T> bool logical_or<T> //逻辑或 template<class T> bool logical_not<T> //逻辑非

January 20, 2022 · 1 min · Rick Cui

函数对象与 predicate 谓词

函数对象 重载函数调用操作符 () 的 类,其对象常称为函数对象 函数对象可以有自己的状态 函数对象可以作为参数传递 一个参数的函数对象叫做一元仿函数 两个参数的函数对象叫做二元仿函数 什么是谓词 返回 bool 类型的仿函数称为谓词 一元谓词 如果 operator() 接受一个参数,那么叫做一元谓词 比如 find_if 算法 二元谓词 如果 operator() 接受两个参数,那么叫做二元谓词 比如 sort 算法

January 20, 2022 · 1 min · Rick Cui

map multimap 容器

特点 所有元素都会根据元素的键值自动排序 默认排序规则是从小到大,可以通过仿函数指定排序规则 map / multimap 属于关联式容器,底层结构是用红黑树实现 不可以修改键值,可以通过删除再插入的方式实现 可以根据 key 值快速找到 value 值 可以通过下标 [] 的方式快速查找、插入和更新对应的 value 案例 公司今天招聘了10个员工(ABCDEFGHIJ),10 名员工进入公司之后,需要指派员工在哪个部门工作 员工信息有: 姓名 工资组成;部门分为:策划、美术、研发 随机给 10 名员工分配部门和工资 通过 multimap 进行信息的插入 key(部门编号) value(员工) 分部门显示员工信息 思路: 创建 10 名员工,放到 vector 中 遍历 vector 容器,取出每个员工,进行随机分组 分组后,将员工部门编号作为 key,具体员工作为 value,放入到 multimap 容器中 分部门显示员工信息 class Worker{ public: Worker(string name, int salary){ m_name = name; m_salary = salary; } void printWorker(){ cout << "姓名:" << m_name << " 工资:" << m_salary << endl; } private: string m_name; int m_salary; }; void createWorkers(vector<Worker> &v){ string nameSeed = "ABCDEFGHIJ"; for(int i = 0; i < nameSeed....

January 20, 2022 · 2 min · Rick Cui