加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

C++之定制操作

发布时间:2020-12-15 04:51:01 所属栏目:百科 来源:网络整理
导读:C++允许我们自己决定算法的操作方式,这就叫做定制操作。通常情况下提供给算法自己定制操作的方式即为 谓词, 谓词是一个可调用的表达式,其返回结果是一个能用作条件的值,标准库算法所使用的谓词可分为两类:一元谓词和二元谓词。 bool isShorter(string s

C++允许我们自己决定算法的操作方式,这就叫做定制操作。通常情况下提供给算法自己定制操作的方式即为谓词,谓词是一个可调用的表达式,其返回结果是一个能用作条件的值,标准库算法所使用的谓词可分为两类:一元谓词和二元谓词。

bool isShorter(string s1,string s2) {

return s1.size() >= s2.size();

}

bool Threshold(string s){

return s.size >=10;

}

int main()

{

vector vec = {……};

//按长度由短至长排序

sort(vec.begin(),vec.end(),isShorter);

find_if(vec.begin(),Threshold);

}

isShorter为二元谓词,决定vec中元素排序的类型。

根据算法接受一元谓词还是二元谓词,我们必须严格传递给算法谓词是一个或者两个参数,这样做太死板,有时我们希望进行的需要更多的参数,需超出谓词的限制,此时可以使用lambda表达式。

lambda表达式

? ? ? ? 一个lambda表达式如下:

? ? ? ? ? ? ? ? [捕获列表](参数列表) ->返回类型 { 函数体 }

? ? ? ? 我们可以忽略参数列表和返回类型,但必须包含捕获列表和函数体。

上面的sort()函数调用可以用lambda表达式重写:

sort(vec.begin(),[](const string &a,const string &b

{return a.size()

//使用捕获列表

find_if(vec.begin(),[sz](const string &s)->bool {return s.size() >= sz;});

未完待续。。。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读