版权声明:本文为博主原创文章,未经博主同意不得转载。

https://blog.csdn.net/cutter_point/article/details/32066151

定制操作

向算法传递函数

用 sort 接受第三个參数!!

谓词

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的元素
计算满足size>=sz的元素的数目
打印长度大于给定值的单词,每一个单词后面接一个空格
这里能够用find_if。嘿嘿!

又来了好东西了。大家是不是感觉幸福来的太突然!!!

find_if接受一对迭代器,表示一个范围,查找有特定大小的元素。

但是啊,这里find_if每次也仅仅能接受一个參数,没法接受一个序列!

这么办呢???

介绍lambda

眼下就两种可调用对象。各自是:函数、函数指针!!。函数指针是干嘛的?
事实上还有两种:重载了函数调用运算符的类,和 嘿嘿,又来了,每次揭晓答案的时候总是忍不住调皮一下
那就是:lambda表达式
[capture list] (parameter list)  -> return type{function body}
诺,这就是那玩意的表现形式。
//是不是有点不一样。这里定义了可调用对象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的更多相关文章

  1. 【足迹C++primer】32、定制操作_2

    版权声明:本文为博主原创文章.未经博主同意不得转载. https://blog.csdn.net/cutter_point/article/details/32301839 定制操作_2 完整的big ...

  2. lambda 表达式定制操作

    泛型算法中的定制操作 许多算法都会比较输入序列中的元素以达到排序的效果,通过定制比较操作,可以控制算法按照编程者的意图工作. 普通排序算法: template<class RandomItera ...

  3. 【足迹C++primer】38、关联容器操作(2)

    版权声明:本文为博主原创文章.未经博主同意不得转载. https://blog.csdn.net/cutter_point/article/details/35244805 关联容器操作(2) map ...

  4. 定制操作(传递函数或lambda表达式)

    很多算法都会比较输入序列中的元素.默认情况下,这类算法使用元素类型的<或==运算符完成比较.标准库还为这些算法定义了额外的版本,允许我们提供自己定义的操作来代替默认运算符. 例如,sort算法默 ...

  5. 【足迹C++primer】表达式求值

    表达式求值 /** * 功能:表达式求值(0到9) * 时间:2014年6月15日08:02:31 * 作者:cutter_point */ #include<stdlib.h> #inc ...

  6. 【足迹C++primer】46、动态存储类

    动态存储类 StrVec Class Design StrVec Class Definition class StrVec { public: //构造函数 StrVec():elements(nu ...

  7. 【足迹C++primer】48、函数引用操作符

    函数引用操作符 struct absInt { int operator()(int val) const { cout<<val<<"<->!!!&qu ...

  8. 【足迹C++primer】47、Moving Objects(1)

    Moving Objects(1) * 功能:Moving Objects * 时间:2014年7月17日08:46:45 * 作者:cutter_point */ #include<iostr ...

  9. 【足迹C++primer】49、超载,变化,运营商

    超载,变化,运营商 Conversion Operators 转换操作符 operator type() const Conversions to an array or a function typ ...

随机推荐

  1. hibernate学习系列-----(4)hibernate基本查询上篇:HQL基本查询

    紧接着上一篇,今天继续hibernate的学习总结,来聊一聊hibernate的基本查询方法,先说说HQL(hibernate Query Language):它是官方推荐的查询语言.在开始写代码之前 ...

  2. x^2 + (y-(x^2)(1/3))^2 = 1 心形方程 5.20无聊之作

    2017.05.20 一个无聊的周六,只能看别人秀恩爱.偶然间在网上看到一个有意思的方程 x^2 + (y-(x^2)(1/3))^2 = 1,据说这个方程可以绘制出一个爱心的形状.既然很无聊,就随便 ...

  3. 【转载】WEB系统性能问题的分析定位方法

    以一个典型的WEB系统来举例,性能问题一般体现在客户端请求后的响应时间上.在性能测试过程中,即压力增大到某个程度后,响应时间指标迅速增长.但如那篇文章所说,这只能叫做一个现象,测试人员需要找到问题所在 ...

  4. 状态机工作流,顺序工作流和Flowchart

    什么是工作流,工作流可以说是对业务处理过程的建模,当我们设计工作流的时候,我们首先要分析业务处理过程中要经历的步骤.然后,我们就可以利用WF创建工作流模型来模拟业务的处理过程. WF工作流包含两种类型 ...

  5. 使用file_get_contents下载图片

        <?php /* 当你在搭建网站时,从远程服务器下载某张图片并且将其保存在自己的服务器上,这一操作会经常用到.代码如下: */ $image = file_get_contents('h ...

  6. 作者:wallimn

    经过这几天对DHTMLXTree的折腾总算是有点眉目了.领导催得紧.组长紧的催. 唉,把握这次机会来好好总结一下DHTMLXTree. 还是老套路.首先来简单了解一下DHTMLXTree. DHTML ...

  7. Nginx:管理HTTP模块的配置项

    参考资料<深入理解Nginx> 一个nginx.conf的例子 http { mytest_num ; server { server_name A; listen ; mytest_nu ...

  8. TCP/IP详解 卷一(第十二章 广播和多播)

    广播和多播仅应用于UDP. 广播指的是一个主机向网上的所有其他主机发送帧,而 多播仅发送给属于多播组的多个主机. 为了弄清广播和多播,需要了解主机对由信道传送过来帧的过滤过程 1.首先,网卡查看由信道 ...

  9. Android_Fragment_Fragment详解

      Android_Fragment_Fragment详解 分类: Android基础2013-10-03 08:23 92人阅读 评论(0) 收藏 举报 AndroidFragmentFragmen ...

  10. Android各种模拟器使用笔记

    [√]天天模拟器 优点: 缺点: 个人经验 ADB 版本过低的解决办法 去启动时的广告方法 去除多余进程方法 ADB无法连接到模拟器 原因分析: 解决方案: 安装APP(APK)时非常非常慢TTMNQ ...