#includeusing namespace std; #include //内建函数对象头文件 //内建函数对象 算数仿函数 //negate 一元仿函数 去反仿函数 void test01() { negate n; cout << n(50) << endl; } //plus 二元仿函数 加法 void test02() { plus p; cout << p(10, 20) << endl; } int main() { //test01(); test02(); system("pause"); return 0; } //总结:使用内建函数对象时,需要引入头文件#include
#includeusing namespace std; #include #include #include //内建函数对象--关系仿函数 //大于greater class MyCompare { public: bool operator()(int v1, int v2) { return v1 < v2; } }; void test01() { vector v; v.push_back(10); v.push_back(30); v.push_back(40); v.push_back(20); v.push_back(50); for (vector ::iterator it = v.begin(); it != v.end(); it++) { cout << *it << " "; } cout << endl; //降序 //sort(v.begin(), v.end(), MyCompare()); //greater ()内建函数对象 sort(v.begin(), v.end(), greater ()); for (vector ::iterator it = v.begin(); it != v.end(); it++) { cout << *it << " "; } cout << endl; } int main() { test01(); system("pause"); return 0; } //总结:关系仿函数中最常用的就是greater<>大于
#includeusing namespace std; #include #include #include //内建函数对象 逻辑仿函数 //逻辑非 logical_not void test01() { vector v; v.push_back(true); v.push_back(false); v.push_back(true); v.push_back(false); for (vector ::iterator it = v.begin(); it != v.end(); it++) { cout << *it << " "; } cout << endl; //利用逻辑非 将容器v搬运到容器v2中,并执行取反操作 vector v2; v2.resize(v.size()); transform(v.begin(), v.end(), v2.begin(), logical_not ()); for (vector ::iterator it = v2.begin(); it != v2.end(); it++) { cout << *it << " "; } cout << endl; } int main() { test01(); system("pause"); return 0; } //总结:逻辑仿函数实际应用较少,了解即可
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)