【足迹C++primer】32、定制操作_1
版权声明:本文为博主原创文章,未经博主同意不得转载。
https://blog.csdn.net/cutter_point/article/details/32066151
定制操作
向算法传递函数
谓词
bool isShorter(const string &s1, const string &s2)
{
return s1.size()<s2.size();
}
int main()
{
//按长度由短至长排序words
sort(words.begin(), words.end(), isShorter);
}
这个words里面是一个string类型的数组,这个调用会是将words重排,全部长度为3的单词排在长度为4的前面,然后是长度为5的单词。
排序算法
近期老碰到排序。冒泡排序什么的已经非常熟悉啦,选择排序不太清楚,什么二分啦,快排啦,哈希啦。就仅仅是知道思路,得努力啊!
!
!
vector<string> words={"fox","jumps","over","quick","red","red","slow","the","the","turtle"};
//按长度由短至长排序words
sort(words.begin(), words.end(), isShorter);
elimDups(words); //将words按字典序重排,并消除反复单词
//按长度重排。长度一样按字典
stable_sort(words.begin(), words.end(), isShorter);
for(const auto &s : words) //无需拷贝字符串
cout<<s<<" "; //打印每一个元素
cout<<endl;
习题:
//调用算法进行排序打印长度大于5的元素
auto it=partition(words.begin(), words.end(), isLong);
//返回的是使谓词为true的最后一个迭代器
cout<<"输出长度大于等于5的字符!
!
"<<endl;
for(vector<string>::iterator st=words.begin() ; st != it ; ++st)
cout<<*st<<" ";
cout<<endl;
lambda表达式
!!
计算满足size>=sz的元素的数目
!
又来了好东西了。大家是不是感觉幸福来的太突然!!!
!
!
!
介绍lambda
//是不是有点不一样。这里定义了可调用对象f,它不接受參数。返回42
auto f=[] {return 42;};
//看哥调用它
cout<<f()<<endl;
这里假设lambda的函数体包括不论什么单一return语句之外的内容、且为指定返回类型。则返回void类型
向lambda传递參数,使用捕获列表
stable_sort(words.begin(), words.end(), [] (const string &a, const string &b)
{return a.size()<b.size();})
void fcn1()
{
vector<string> words={"fox","jumps","over","quick","red","red","slow","the","the","turtle"};
size_t v1 = 42;
//获取一个迭代器,指向第一个满足size()>=v1的元素
auto wc=find_if(words.begin(), words.end(), [v1](const string &a){return a.size()>=v1;});
}
void fcn2()
{
vector<string> words={"fox","jumps","over","quick","red","red","slow","the","the","turtle"};
size_t v1 = 42;
//获取一个迭代器。指向第一个满足size()>=v1的元素
auto wc=find_if(words.begin(), words.end(), [v1](const string &a){return a.size()>=v1;});
//计算满足size>=sz的元素的数目
auto count=words.end()-wc;
cout<<count<<" "<<make_plural(count, "word", "s")
<<" of length "<<v1<<" or longer "<<endl;
//for_each算法
for_each(wc, words.end(),[](const string &s){cout<<s<<" yeah! ";});
}
【足迹C++primer】32、定制操作_1的更多相关文章
- 【足迹C++primer】32、定制操作_2
版权声明:本文为博主原创文章.未经博主同意不得转载. https://blog.csdn.net/cutter_point/article/details/32301839 定制操作_2 完整的big ...
- lambda 表达式定制操作
泛型算法中的定制操作 许多算法都会比较输入序列中的元素以达到排序的效果,通过定制比较操作,可以控制算法按照编程者的意图工作. 普通排序算法: template<class RandomItera ...
- 【足迹C++primer】38、关联容器操作(2)
版权声明:本文为博主原创文章.未经博主同意不得转载. https://blog.csdn.net/cutter_point/article/details/35244805 关联容器操作(2) map ...
- 定制操作(传递函数或lambda表达式)
很多算法都会比较输入序列中的元素.默认情况下,这类算法使用元素类型的<或==运算符完成比较.标准库还为这些算法定义了额外的版本,允许我们提供自己定义的操作来代替默认运算符. 例如,sort算法默 ...
- 【足迹C++primer】表达式求值
表达式求值 /** * 功能:表达式求值(0到9) * 时间:2014年6月15日08:02:31 * 作者:cutter_point */ #include<stdlib.h> #inc ...
- 【足迹C++primer】46、动态存储类
动态存储类 StrVec Class Design StrVec Class Definition class StrVec { public: //构造函数 StrVec():elements(nu ...
- 【足迹C++primer】48、函数引用操作符
函数引用操作符 struct absInt { int operator()(int val) const { cout<<val<<"<->!!!&qu ...
- 【足迹C++primer】47、Moving Objects(1)
Moving Objects(1) * 功能:Moving Objects * 时间:2014年7月17日08:46:45 * 作者:cutter_point */ #include<iostr ...
- 【足迹C++primer】49、超载,变化,运营商
超载,变化,运营商 Conversion Operators 转换操作符 operator type() const Conversions to an array or a function typ ...
随机推荐
- Android学习(四) Layout五大布局
我们知道Android系统应用程序一般是由多个Activity组成,而这些Activity以视图的形式展现在我们面前, 视图都是由一个一个的组件构成的.组件就是我们常见的Button.TextEdit ...
- android 4.0 禁用系统home键
2.2 禁用系统home键.这里不说了. 近期项目有一个需求,禁用系统的全部键.像menu, home, back.同一时候还要是想点击响应与view的弹出. 就是UI这部分要正常. back键我们自 ...
- TCP/IP 网络编程(五)
优于 select 的 epoll (I/O 复用) select 速度慢的原因 调用select后针对全部文件描写叙述符的循环 每次调用函数时都须要向该函数传递监视对象信息 select并非把发生变 ...
- java web 分页实现
分页实现的效果: ///////// /////////////////////////////////////////////////////// /////////////////// ...
- css 用 display: inline-block; 代替 float
浮动可以将两个块级元素浮动在同一水平上.但float的缺点也有很多,还需要其他样式弥补. 早年我使用过 display: inline-block; 但苦于兼容性问题一直没敢全面使用. 近几年主要玩移 ...
- css 温故而知新 1px的问题
解决方法1: //border @mixin border($pos, $color) { content: ""; position: absolute; transform-o ...
- Memcached的LRU和缓存命中率
缓存命中率 命中:直接从缓存中读取到想要的数据. 未中:缓存中没有想要的数据,还需要到数据库进行一次查询才能读取到想要的数据. 命中率越高,数据库查询的次数就越少. 读取缓存的速度远比数据库查询的速度 ...
- github上比較好的开源项目(持续更新)
1:https://github.com/Skykai521/StickerCamera 实现相机功能 实现对图片进行裁剪的功能 图片的滤镜功能 能为图片加入贴纸(贴纸可移动,放大,旋转) 能为图片加 ...
- asp.net repeater Container.ItemIndex
<asp:Repeater ID="myRepeater" runat="server"> <HeaderTemplate> <t ...
- PyQt5 Function Parameter Declaration
addWidget self.lcd = QLCDNumber() grid.addWidget(self.lcd,0,0,3,0) grid.setSpacing(10) void QGridLay ...