,
,
组成for_each(iterator beg, iterator end, _func);
//遍历容器beg
//起始迭代器end
//结束迭代器_func()
//函数或函数对象for_each是实际开发中最常用的遍历算法,需要熟练掌握
#include#include#includeusing namespace std;//普通函数void myPrint(int val){ cout << val << " ";}//仿函数class myPrint2{public: void operator()(int val) { cout << val << " "; }};int main(){ vectorv; for (int i = 0; i < 10; i++) { v.push_back(i); } for_each(v.begin(), v.end(), myPrint); cout << endl; for_each(v.begin(), v.end(), myPrint2()); return 0;}
transform搬运
transform(iterator beg1, iterator end1, iterator beg2, _func);
//搬运容器
(资料图片)
beg1
//源容器开始迭代器end1
//源容器结束迭代器beg2
//目标容器开始迭代器_func
//函数或函数对象搬运的目标容器必须提前开辟空间,否则无法正常搬运
#include#include#includeusing namespace std;class Transform{public: int operator()(int val) { return val; }};int main(){ vectorv; for (int i = 0; i < 10; i++) { v.push_back(i); } vectorv2; v2.resize(v.size()); transform(v.begin(), v.end(), v2.begin(), Transform()); for (vector::iterator it = v2.begin(); it != v2.end(); it++) { cout << *it << " "; } return 0;}
常用查找算法
find
//查找元素find_if
//按条件查找元素adjacent_find
//查找相邻重复元素binary_search
//二分查找法count
//统计元素个数count_if
//按条件统计元素个数find按值查找find(iterator beg, iterator end, value);
//按值查找beg
//开始迭代器end
//结束迭代器value
//查找的元素返回一个迭代器,如果没有找到,返回end()
查找自定义数据类型需要重载==运算符,否则底层不知道如何对比
#include#include#includeusing namespace std;//查找内置数据类型void test01(){ vectorv; for (int i = 0; i < 10; i++) { v.push_back(i); } //返回一个迭代器,如果没有找到,返回end() vector::iterator it = find(v.begin(), v.end(), 5); if (it == v.end()) cout << "没找到" << endl; else cout << "找到了" << *it << endl;}//查找自定义数据类型class Person{public: Person(string name,int age) { this->m_age = age; this->m_name = name; } //重载==运算符,让find知道如何对比Person类型数据 bool operator==(const Person& p) { if (p.m_age == this->m_age && p.m_name == this->m_name) return true; else return false; } string m_name; int m_age;};void test02(){ //准备数据 Person p1("A", 1); Person p2("B", 2); Person p3("C", 3); Person p4("D", 4); Person p5("E", 5); //放入容器中 vectorp; p.push_back(p1); p.push_back(p2); p.push_back(p3); p.push_back(p4); p.push_back(p5); //查找 Person p6("A", 1); vector::iterator it = find(p.begin(), p.end(), p6); //输出,验证结果 if (it == p.end()) cout << "没找到" << endl; else cout << "找到了" << it->m_name << it->m_age << endl;}int main(){ test01(); test02(); return 0;}
find_if条件查找
find_if(iterator beg, iterator end, _Pred);
beg
//开始迭代器#includeadjacent_find(iterator beg, iterator end)
end
//结束迭代器_Pred
//函数或者谓词(返回bool数据类型的仿函数)beg
//开始迭代器#includebool binary_search(iterator beg, iterator end, value);
end
//结束迭代器查找指定的元素,查到返回true,否则返回false#includecount_if(iterator beg, iterator end, _Pred);
注意:在无序列表中不可用,如果是无序序列,结果未知beg
//开始迭代器end
//结束迭代器value
//查找的元素beg
//开始迭代器#includeend
//结束迭代器_Pred
//函数或者谓词(返回bool数据类型的仿函数)sort
//对容器内元素进行排序random_shuffle
//随机洗牌,将指定范围内的元素重新排序merge
//容器元素合并,并储存到另一个容器中reverse
//反转指定范围的元素sort排序sort(iterator beg, iterator end, _Pred)
//排序beg
//开始迭代器#includerandom_shuffle(iterator beg, iterator end);
//随机洗牌end
//结束迭代器_Pred
//函数或者谓词,可填可不填,不填则默认升序排列只需要提供开始迭代器和结束迭代器srand((unsigned int)time(NULL));
可以设置系统时间为随机数种子
#include#include#includeusing namespace std;void test01(){ vectorv; for (int i = 0; i < 10; i++) { v.push_back(i); } random_shuffle(v.begin(), v.end()); for (vector::iterator it = v.begin(); it != v.end(); it++) { cout << *it << " " ; } cout << endl;}int main(){ test01(); return 0;}
merge合并
merge(iterator beg1, iterator end1, iterator beg2, iterator end2, dest);
//将两个容器元素合并,并储存到另一个容器中
reverse(iterator beg, iterator end);
//反转指定范围内的元素beg1
//容器1开始迭代器end1
//容器1结束迭代器beg2
//容器2开始迭代器end2
//容器2结束迭代器dest
//目标容器开始迭代器beg
//起始迭代器#includeend
//结束迭代器copy
//容器内指定范围的元素拷贝到另一个容器中replace
//将容器内指定范围的旧元素修改为新元素replace_if
//容器内指定范围满足条件的元素替换为新元素swap
//互换两个容器的元素copy拷贝copy(iterator beg, iterator end, iterator dest);
//容器内指定范围的元素拷贝到另一个容器中beg
//开始迭代器end
//结束迭代器dest
//目标容器的开始迭代器用到的比较少,直接用赋值操作更简单
#include#include#includeusing namespace std;void Print(int val){ cout << val << " ";}void test01(){ vectorv1; for (int i = 0; i < 10; i++) { v1.push_back(i); } vectorv2; //v2要提前开辟空间 v2.resize(v1.size()); copy(v1.begin(), v1.end(), v2.begin()); for_each(v2.begin(), v2.end(), Print);}int main(){ test01(); return 0;}
replace替换
replace(iterator beg, iterator end, oldvalue, newvalue);
//将区间内的旧元素替换为新元素
beg
//起始迭代器#includereplace_if(iterator beg, iterator end, _Pred, newvalue);
//容器内指定范围满足条件的元素替换为新元素end
//结束迭代器oldvalue
//旧元素newvalue
//新元素beg
//开始迭代器#includeswap(container c1, container c2);
//互换两个容器的元素end
//结束迭代器_Pred
//谓词newvalue
//替换的新元素c1
容器1c2
容器2注意必须是同种容器
#include#include#includeusing namespace std;class Print{public: void operator()(int val) { cout << val << " "; }};class GreaterFive{public: bool operator()(const int& val) { return val > 5; }};void test01(){ vectorv1; vectorv2; for (int i = 0; i < 10; i++) { v1.push_back(i); v2.push_back(i + 2); } //交换前 for_each(v1.begin(), v1.end(), Print()); for_each(v2.begin(), v2.end(), Print()); cout << endl; //交换后 swap(v1, v2); for_each(v1.begin(), v1.end(), Print()); for_each(v2.begin(), v2.end(), Print());}int main(){ test01(); return 0;}
常用算术生成算法
算术生成算法属于小型算法,使用时包含的头文件为
accumulate
//计算容器元素累计总和fill
//向容器中添加元素accumulate累积accumulate(iterator beg, iterator end, value);
//计算容器元素累计总和beg//起始迭代器#includefill(iterator beg, iterator end, value);
//向容器中添加元素end//结束迭代器value//起始值beg
//起始迭代器#includeend
//结束迭代器value
//填充的值set_intersection
//求两个容器的交集set_union
//求两个容器的并集set_difference
//求两个容器的差集set_intersection求交集set_intersection(iterator beg1, iterator end1, iterator beg2, iterator end2, iterator dest);
//求两个容器的交集beg1
//容器1开始迭代器end1
//容器1结束迭代器beg2
//容器2开始迭代器end2
//容器2结束迭代器dest
//目标容器开始迭代器注意事项:
返回值为迭代器,指向交集最后一个元素的下一个位置求交集的两个集合必须为有序数列目标容器开辟空间需要从两个容器中取小值交集就是两个容器重复的元素
#include#include#include#includeusing namespace std;void myPrint(int val){ cout << val << " ";}void test01(){ vectorv1; vectorv2; for (int i = 0; i < 10; i++) { v1.push_back(i); v2.push_back(i + 2); } for_each(v1.begin(), v1.end(), myPrint); cout << endl; for_each(v2.begin(), v2.end(), myPrint); cout << endl; //目标容器需要提前开辟空间,最特殊的情况,大容器包含小容器 vectorv3; v3.resize(min(v1.size(), v2.size())); //取交集 vector::iterator itEnd = set_intersection(v1.begin(), v1.end(), v2.begin(), v2.end(), v3.begin()); for_each(v3.begin(), itEnd, myPrint); cout << endl; //如果不用返回的itEnd,会把0也给打印出来 for_each(v3.begin(), v3.end(), myPrint);}int main(){ test01(); return 0;}
set_union求并集
set_union(iterator beg1, iterator end1, iterator beg2, iterator end2, iterator dest);
//求两个容器的并集
beg1
//容器1开始迭代器end1
//容器1结束迭代器beg2
//容器2开始迭代器end2
//容器2结束迭代器dest
//目标容器开始迭代器注意事项:
返回值为迭代器,指向并集最后一个元素的下一个位置#includeset_difference(iterator beg1, iterator end1, iterator beg2, iterator end2, iterator dest);
//求两个容器的差集求并集的两个集合必须为有序数列目标容器开辟空间需要两个容器相加beg1
//容器1开始迭代器end1
//容器1结束迭代器beg2
//容器2开始迭代器end2
//容器2结束迭代器dest
//目标容器开始迭代器注意事项:
返回值为迭代器,指向并集最后一个元素的下一个位置#includetransform(iteratorbeg1,iteratorend1,iteratorbeg2,_func); 搬运容器2023-02-13
历史上真有茅载这一个人吗,茅载只是塑造的一个人物,茅载原型为三大亨之一的张啸林,中华民国时期上海青帮头目之一。原名小林,乳名阿虎,后2023-02-13
1、《人在旅途洒泪时》、《俩忘烟水里》、《大地恩情》、《龙的传人》、《情爱几多哀》、《天蚕变》、《万水千山纵横》、《星》2023-02-13
近日,全新Jeep大切诺基(参数丨图片)4xe在国内预售,起订价65万起,Jeep又重新做起了豪华梦。这款全新Jeep大切诺基4xe版本搭载的是2 0T发动机+2023-02-13
1、亮子湖风景区,又称梁紫湖中的娘子湖,位于江夏区。这里的主要景点是青山岛、亮子岛和田字,盛产武昌鱼和螃蟹。坐船去那个岛需要半个小时。2023-02-13
以下是零点有数在北京时间2月13日14:23分盘口异动快照:2月13日,零点有数盘中快速反弹,5分钟内涨幅超过2%,截至14点23分,报44 81元,成交42023-02-13
1、妙祥法师,一九九五年自五台山行脚回至辽宁,后在本溪茅蓬闭关三年。2、于二〇〇〇年应当地政府及信众邀请率僧团至大悲寺住2023-02-13
可以送一些健身的保健类产品,比如按摩器,按摩器等等,当然也可以选择一些按摩器之类的礼物,像按摩器,或者足浴盆,按摩器之类2023-02-13
今年以来,各地发力扩大投资。据《证券日报》记者梳理,截至2月12日,多地发布了2023年重大项目投资清单,总投资额合计达21 5万亿元。从投资项2023-02-13
定了!全新雷克萨斯RX RZ将于2月14日正式上市,新车,上市,四驱系统,suv车型,雷克萨斯rx2023-02-12
虫孽,关于虫孽的介绍很多人还不知道,现在让我们一起来看看吧!1、《虫孽》是2000年日本出品的一部动画,总共26集。2、2023-02-12
美国内华达州州长宣布该州因燃料管道泄漏进入紧急状态2023-02-12
据外媒,垂直一体化磁铁技术公司美国稀土公司周四宣布,美国前国务卿迈克·蓬佩奥已加入美国稀土公司,担任战略顾问。首席执行官汤姆·施奈德2023-02-12
送康乃馨,因为康乃馨象征着百年好合,康乃馨象征着温馨,黄康乃馨是母亲最爱的象征。给老师送花比较适合,比如康乃馨,康乃馨2023-02-11
ESPN记者KendraAndrews报道,勇士在体检时发现了加里-佩顿二世有重大伤病,四方交易面临取消的危险。由于交易截止日已过,交易无法修改,只能2023-02-11
如果说古风是中国传统文化的新发展,那么古风CG插画则是一种新的风格和艺术形式。在几年前,古风插画基本都是圈地自萌,但现在,潮流趋势2023-02-11
参考消息网2月11日报道据俄罗斯卫星社11日援引《印度防务新闻》报道,F-35战机参加印度航空展可能与美国希望向印度供应该(@参考消息)2023-02-11
原标题:太原文化旅游推介招商大会将于2月13日至15日开幕锦绣太原,于斯益彰。为推进文化旅游发展,加大文旅项目招商力度,2023-02-11
1、国学大师梁启超先生经典名作,倾情解读晚清重臣李鸿章的功业与悲情!上承曾国藩,下启袁世凯,晚清改革总设计师。2、欲了解近代中国,不可2023-02-11
八个队长几几礼物,八个月大了,是爷爷的节日。爷爷的生日是在三百天。这是我爷爷在外地的,给爷爷过的第一个节日。爷爷从小到大2023-02-11
1、湖南辰投碣滩茶业开发有限公司于2018年03月22日成立。2、法定代表人宋强,公司经营范围包括:茶叶的批发;茶叶2023-02-11
因为在淘宝上面购买裤子是没有办法试穿的,而有些人又觉得退货是一件麻烦的事情,就想着去淘宝上面买就能够买到合适大小的裤子,这就要求各位2023-02-11
2月10日,华森制药发布业绩快报,公司2022年1-12月实现营业收入7 84亿元,同比下降7 34%;归属于上市公司股东的净利润9502 46万元,同比增长32023-02-10
商业软文推广类型与渠道有很多,除了常规的权威网站外,一些自媒体平台的商业软文投放效果也非常不错,例如有“国民种草社区”之称的小红书,2023-02-10
普京:俄方没挑起在乌克兰的敌对行动,而是试图结束它们,普京,战争,乌克兰,俄罗斯,克里米亚2023-02-10
