【C++ Primer | 07】泛型算法
定制操作
#include <iostream> #include <string> #include <vector> #include <algorithm> #include <numeric> #include <list> using namespace std; template <typename Sequence> inline ostream& println(Sequence const& seq) { for (auto const& elem : seq) cout << elem << " "; cout << endl; return cout; } inline bool is_shorter(std::string const& lhs, std::string const& rhs) { return lhs.size() < rhs.size(); } void elimdups(vector<string> &vs) { sort(vs.begin(), vs.end()); auto new_end = unique(vs.begin(), vs.end()); vs.erase(new_end, vs.end()); } int main() { vector<", "Hi", "alan", "wang" }; elimdups(v); stable_sort(v.begin(), v.end(), is_shorter); cout << "ex10.11 :\n"; println(v); system("pause"); ; }
输出结果:
Exercise 10.14:
int main() { auto sum = [](int a, int b) {return a + b; }; cout << sum(, ) << endl; ; }
Exercise 10.16
#include <iostream> #include <string> #include <vector> #include <algorithm> using namespace std; void elimdups(vector<string> &vs) { sort(vs.begin(), vs.end()); for (auto c : vs) cout << c << " "; cout << endl; auto new_end = unique(vs.begin(), vs.end()); vs.erase(new_end, vs.end()); for (auto c : vs) cout << c << " "; cout << endl; } void biggies(vector<string> &vs, size_t sz) { elimdups(vs); stable_sort(vs.begin(), vs.end(), [](string const& lhs, string const& rhs) { return lhs.size() < rhs.size(); }); auto wc = find_if(vs.begin(), vs.end(), [sz](string const& s) { return s.size() >= sz; }); for_each(wc, vs.end(), [](const string &s) { cout << s << " "; }); } int main() { vector<string> v{ ","hi~", "alan", "alan", "cp" }; cout << "ex10.16: " << endl; biggies(v, ); cout << endl; system("pause"); ; }
输出结果:
Exercise 10.18、10.19
#include <iostream> #include <string> #include <vector> #include <algorithm> using namespace std; // from ex 10.9 void elimdups(vector<string> &vs) { sort(vs.begin(), vs.end()); auto new_end = unique(vs.begin(), vs.end()); vs.erase(new_end, vs.end()); for (auto it = vs.cbegin(); it != vs.end(); ++it) cout << *it << " "; cout << endl; } // ex10.18 void biggies_partition(vector<string> &vs, size_t sz) { elimdups(vs); auto pivot = partition(vs.begin(), vs.end(), [sz](const string &s) { return s.size() >= sz; } ); for (auto it = vs.cbegin(); it != pivot; ++it) cout << *it << " "; } // ex10.19 void biggies_stable_partition(vector<string> &vs, std::size_t sz) { elimdups(vs); auto pivot = stable_partition(vs.begin(), vs.end(), [sz](const string& s) { return s.size() >= sz; }); for (auto it = vs.cbegin(); it != pivot; ++it) cout << *it << " "; } int main() { // ex10.18 vector<string> v{ "the", "quick", "red", "fox", "jumps", "over", "the", "slow", "red", "turtle" }; cout << "ex10.18: "; vector<string> v1(v); biggies_partition(v1, ); cout << endl; // ex10.19 cout << "ex10.19: "; vector<std::string> v2(v); biggies_stable_partition(v2, ); cout << endl; system("pause"); ; }
输出结果:
参数绑定
Exercise 10.22:
#include <iostream> #include <vector> #include <string> #include <algorithm> #include <functional> using namespace std; using namespace std::placeholders; bool isLesserThanOrEqualTo6(const string &s, string::size_type sz) { return s.size() <= sz; } int main() { vector<string> authors{ "Mooophy", "pezy", "Queequeg90", "shbling", "evan617" }; cout << count_if(authors.cbegin(), authors.cend(), bind(isLesserThanOrEqualTo6, _1, )) << endl; system("pause"); ; }
Exercise 10.24:
#include <iostream> #include <vector> #include <algorithm> #include <functional> using namespace std; using namespace std::placeholders; auto check_size(string const& str, size_t sz) { return str.size() < sz; } int main() { vector<, , , , , , , }; "); auto result = find_if(vec.begin(), vec.end(), bind(check_size, str, _1)); if (result != vec.end()) cout << *result << endl; else cout << "Not found" << endl; system("pause"); ; }
#include <iostream> #include <vector> #include <algorithm> #include <functional> using namespace std; using namespace std::placeholders; auto check_size(string const& str, size_t sz) { return str.size() < sz; } int main() { vector<int> vec{ 0, 1, 2, 3, 4, 5, 6, 7 }; string str("123456"); auto result = find_if(vec.begin(), vec.end(), bind(check_size, str, _1)); if (result != vec.end()) cout << *result << endl; else cout << "Not found" << endl; system("pause"); return 0; }
#include <iostream> #include <vector> #include <algorithm> #include <functional> using namespace std; using namespace std::placeholders; auto check_size(string const& str, size_t sz) { return str.size() < sz; } int main() { vector<int> vec{ 0, 1, 2, 3, 4, 5, 6, 7 }; string str("123456"); auto result = find_if(vec.begin(), vec.end(), bind(check_size, str, _1)); if (result != vec.end()) cout << *result << endl; else cout << "Not found" << endl; system("pause"); return 0; }
【C++ Primer | 07】泛型算法的更多相关文章
- c++ primer 11 泛型算法
使用泛型算法必须包含头文件#inlucde <algorithm> 标准库还定义一组泛化的算术算法,其命名习惯与泛型算法相同,包含头文件#include <numeric> f ...
- C++ Primer : 第十章 : 泛型算法 之 只读、写和排序算法
大多数算法都定义在<algorithm>头文件里,而标准库还在头文件<numeric>里定义了一组数值泛型算法,比如accumulate. ● find算法,算法接受一对迭代 ...
- C++ Primer 5th 第10章 泛型算法
练习10.1:头文件algorithm中定义了一个名为count的函数,它类似find,接受一对迭代器和一个值作为参数.count返回给定值在序列中出现的次数.编写程序,读取int序列存入vector ...
- C++ Primer 读书笔记:第11章 泛型算法
第11章 泛型算法 1.概述 泛型算法依赖于迭代器,而不是依赖容器,需要指定作用的区间,即[开始,结束),表示的区间,如上所示 此外还需要元素是可比的,如果元素本身是不可比的,那么可以自己定义比较函数 ...
- 【足迹C++primer】30、概要(泛型算法)
概要(泛型算法) 大多数算法的头文件中定义algorithm在. 标准库也是第一个文件numeric它定义了一套通用算法. #include<iostream> #include<n ...
- 【C++ Primer | 07】常用算法
第一部分 常用泛型算法: find(beg, end, val); equal(beg1, end1, beg2); fill(beg, end, val); fill_n(beg, cnt, val ...
- [C++ Primer] : 第10章: 泛型算法
概述 泛型算法: 称它们为"算法", 是因为它们实现了一些经典算法的公共接口, 如搜索和排序; 称它们是"泛型的", 是因为它们可以用于不同类型的元素和多种容器 ...
- C++ Primer 学习笔记_45_STL实践与分析(19)--泛型算法的结构
STL实践与分析 --泛型算法的结构 引言: 正如全部的容器都建立在一致的设计模式上一样,算法也具有共同的设计基础. 算法最主要的性质是须要使用的迭代器种类.全部算法都指定了它的每一个迭代器形參可使用 ...
- C++ Primer笔记6_STL之泛型算法
1.泛型算法: 大多数算法定义在头文件algorithm中.标准库还在头文件numeric中定义了一组数值泛型算法 仅仅读算法: 举例: find函数用于找出容器中一个特定的值,有三个參数 int v ...
- C++ 泛型算法
<C++ Primer 4th>读书笔记 标准容器(the standard container)定义了很少的操作.标准库并没有为每种容器类型都定义实现这些操作的成员函数,而是定义了一组泛 ...
随机推荐
- Unique Morse Code Words
Algorithm [leetcode]Unique Morse Code Words https://leetcode.com/problems/unique-morse-code-words/ 1 ...
- Linux只读账号配置【转】
整个配置的命令如下(主要使用了:Linux bash受限的shell(RESTRICTED SHELL)) 步骤#1.创建只读shell(这步可以省略) ln -s /bin/bash /bin/rb ...
- async_mongo_helper
# -*- coding: utf-8 -*- # @Time : 2019/1/7 2:11 PM # @Author : cxa # @File : motortesdt.py # @Softwa ...
- 利用微信企业号的告警功能,联动检测ICMP的shell脚本
作者:邓聪聪 由于设备IP众多,为了及时发现IP地址有不可达现象,利用微信的联动报警,及时发现问题,以下是脚本内容!!! ping.sh #!/bin/bash ###SCRIPT_NAME:icmp ...
- 【转】thread.sleep(0)与thread.sleep(1)的区别
Thread.Sleep(0) Sleep的意思是告诉操作系统自己要休息n毫秒,这段时间就让给一个就绪的线程吧.当n=0时,意思是要放弃自己剩下的时间片,但是仍然是就绪状态.Sleep(0)只允许那些 ...
- Mudo C++网络库第八章学习笔记
muduo网络库的设计与实现 muduo是基于Reactor模式的C++网络库; Reactor的关键结构 Reactor最核心的是事件分发机制, 即将IO multiplexing拿到IO事件分发给 ...
- NDK历史版本下载方法
再比如说,你要下载Android NDK, Revision 8b ,只要下面链接就可以了: http://dl.google.com/android/ndk/android-ndk-r8b-Linu ...
- Light OJ 1095
题意: 给你 N 个数, 总共有 N! 种排列, 现在 要你统计前 M 个数 刚好 有K 个数 在原来的位置上 的排列个数 思路: 首先 M 中选 K C(m,k): 则 共 剩下 n - k 个数, ...
- 前端 -----jQuery的位置信息
08-jQuery的位置信息 jQuery的位置信息跟JS的client系列.offset系列.scroll系列封装好的一些简便api. 一.宽度和高度 获取宽度 .width() 描述:为匹配的 ...
- 深入Golang调度器之GMP模型
前言 随着服务器硬件迭代升级,配置也越来越高.为充分利用服务器资源,并发编程也变的越来越重要.在开始之前,需要了解一下并发(concurrency)和并行(parallesim)的区别. 并发: 逻 ...