1、find(begin(),end(),value);value是值。
看到底层就是一个迭代 ,循环。从begin()到end()的一个循环,如果 *it==value 就返回it 那么 我们就是只需要,重载 这个类 ,vector这个person 类中的符号 = = 符号,不需要返回值,
bool operator= =( const person &p ){
if(this->name = p->name&&this->age = p->age ){
return true;
}
else{
return flase;
}
}
算法后面的pre 都是谓词?
谓词都是bool 类型。
bool operator()(Person &p){
return p->age >20;
}
有一个找到年龄大于 20的
当multiSet的时候,可以有重复值,那么和之前员工那道题一样,做一个for循环,
得到cont,从迭代器 起始位置开始读取。
就是 查找一个 自己创建的类型,先定义好排序
class compare
bool operator()(Person p1,Person p2 ){
return p1>p2;//大的在前 就是降序。
}
创建一个sort(begin(),end(),compare());排好序
之后再 得到一个Greater的迭代器,再得到cout 计数。
就可以输出之后 得满足条件的内容。