25.不改变原生数据的STL algorithm
- 通过仿函数for_each操作
vector<int> myv{ ,,,, };
list<double> db{ 1.1,2.2,3.3,4.4,5.5 }; //循环算法,算法的泛型
print p = for_each(db.begin(), db.end(), print());
cout << p.count << endl; - find_if查找算法
//查找算法
auto it = find(myv.begin(), myv.end(), );
cout << *it << endl; - find_if与lambda结合
//寻找第一个偶数的位置,返回0就是找到的
auto it = find_if(myv.begin(), myv.end(), [](int x)->bool
{
if (x % == )
{
return ;
}
else
{
return ;
}
}); if (it != myv.end())
{
cout << *it << " pos=" << it - myv.begin() << endl;
} - adjacent_find处理相邻的两个数据
list <int> mylist{ ,,,,,,, };
//查找相邻的两个元素相等的位置(adjacent_find处理相邻的两个数据)
auto it = adjacent_find(mylist.begin(), mylist.end());
if (it != mylist.end())
{
cout << *it << endl;
it++;
cout << *it << endl;
} - adjacent_find与lambda结合
//寻找第一个奇偶性不同的
auto it = adjacent_find(mylist.begin(), mylist.end(), [](int x,int y)->bool
{
if ((x - y) % == )
{
return ;
}
else
{
return ;
}
});
if (it != mylist.end())
{
cout << *it << endl;
it++;
cout << *it << endl;
} - find_first_of寻找第一个集合在第二个集合中出现的第一个数据
char *str1 = "";
char *str2 = "abcdefg123";
//寻找在string1中第一个出现在string2的字符
char *p = find_first_of(str1, str1 + strlen(str1), str2, str2 + strlen(str2));
cout << *p << endl; vector<int> myint1{ ,,,, };
vector<int> myint2{ ,,,, };
auto it = find_first_of(myint1.begin(), myint1.end(), myint2.begin(), myint2.end());
cout << *it << endl; - count与count_if查询数据个数
vector<int> myint{ ,,,,,,,,, };
int count1 = count(myint.begin(), myint.end(), );
cout << count1 << endl; //查询所有小于4的元素的个数
int count2 = count_if(myint.begin(), myint.end(), [](int x)
{
if (x < )
{
return ;
}
else
{
return ;
}
});
cout << count2 << endl; - mismatch判断两个集合是否相等
vector<int> myint1{ ,,,,,,,,, };
vector<int> myint2{ ,,,,,,,,, }; auto it = mismatch(myint1.begin(), myint1.end(), myint2.begin());
if (it.first == myint1.end() && it.second == myint2.end())
{
cout << "相等" << endl;
}
else
{
//first是第一个容器不匹配的位置(可能为空),second是第二个容器不匹配的位置(可能为空)
cout << "不相等" << endl;
cout << *(it.first) <<" " << *(it.second) << endl;
}char *s1[] = { "abc","acv","adf","oop" };
char *s2[] = { "abc","acv","adf","oop","" };
auto it = mismatch(s1, s1 + , s2, [](const char* str1,const char* str2)
{
if (strcmp(str1, str2) == )
{
return ;
}
else
{
return ;
}
}); if (it.first == s1 + sizeof(s1)/sizeof(s1[]) && it.second == s2 + sizeof(s2) / sizeof(s2[]))
{
cout << "相等" << endl;
}
else
{
//first是第一个容器不匹配的位置(可能为空),second是第二个容器不匹配的位置(可能为空)
cout << "不相等" << endl;
//cout << *(it.first) << " " << *(it.second) << endl;
} - equal判断是否是一样的集合
vector<int> myv1{ ,,,, };
vector<int> myv2{ -,,-,,- }; //判断绝对值知否相等
if (equal(myv1.begin(), myv1.end(), myv2.begin(), [](int a, int b) ->bool
{
if (a == abs(b) || b == abs(a))
{
return ;
}
else
{
return ;
}
}))
{
cout << "相等" << endl;
}
else
{
cout << "不相等" << endl;
} - search判断有没有连续一样的部分
vector<int> myv1{ , };
vector<int > myv2{ ,,,, }; //判断有没有连续相等的子集
auto it = search(myv1.begin(), myv1.end(), myv2.begin(), myv2.end()); if (it == myv1.end())
{
cout << "是子集" << endl;
}
else
{
cout << "不是子集" << endl;
} - search_n判断有没有连续一样的数据
vector<int> myv1{ ,,,,,, }; //判断有没有连续相等的数据
auto it = search_n(myv1.begin(), myv1.end(),, ); if (it == myv1.end())
{
cout << "有" << endl;
}
else
{
cout << "没有" << endl;
} - 从反向寻找一个集合在另一个集合中出现的位置
vector<int> myv2{ ,,,,,, };
vector<int> myv3{ , };
//在myv2中从后往前找myv3所在的位置
auto it = find_end(myv2.begin(), myv2.end(), myv3.begin(), myv3.end()); if(it != myv2.end())
{
cout << *it << " " << it - myv2.begin() << endl;
}
25.不改变原生数据的STL algorithm的更多相关文章
- SharePoint 2010 升级到2013时间 为了确保用户可以连接,但无法改变升级数据
SharePoint 2010 升级到2013时间 为了确保用户可以连接,但无法改变升级数据 我总结的步骤 红色请注意它们的含义. 步骤1:连接到SQL DBS 上的SharePoint 2010数据 ...
- 【ArcGIS 10.2新特性】ArcGIS 10.2将PostgreSQL原生数据发布为要素服务
1.ArcGIS 10.2支持原生数据发布为要素服 有没有将自己已有的空间数据发布为要素服务的需求?有没有将非Esri空间数据类型的数据作为服务在Web端展示的需求? ArcGIS 10.2 ...
- 14Flutter StatefulWidget有状态组件、页面上绑定数据、改变页面数据、实现计数器功能、动态列表
/** * Flutter StatefulWidget有状态组件.页面上绑定数据.改变页面数据 * 在Flutter中自定义组件其实就是一个类,这个类需要继承StatelessWidget/Stat ...
- 使用 Iceberg on Kubernetes 打造新一代云原生数据湖
背景 大数据发展至今,按照 Google 2003年发布的<The Google File System>第一篇论文算起,已走过17个年头.可惜的是 Google 当时并没有开源其技术,& ...
- Fluid + GooseFS 助力云原生数据编排与加速快速落地
前言 Fluid 作为基于 Kubernetes 开发的面向云原生存算分离场景下的数据调度和编排加速框架,已于近期完成了 v0.6.0 版本的正式发布.腾讯云容器 TKE 团队一直致力于参与 Flui ...
- STL algorithm 头文件下的常用函数
algorithm 头文件下的常用函数 1. max(), min()和abs() //max(x,y)和min(x,y)分别返回x和y中的最大值和最小值,且参数必须时两个(可以是浮点数) //返回3 ...
- Flutter StatefulWidget 有状态组件、页面上绑定数据、改变页面数据
在 Flutter 中自定义组件其实就是一个类,这个类需要继承 StatelessWidget/StatefulWidget. StatelessWidget 是无状态组件,状态不可变的 widget ...
- php 封装原生数据导入的方法(csv文件格式)
//前端---部分代码 <form class="form-inline" style="margin-top: 20px" method="p ...
- StatelessWidget 无状态组件 StatefulWidget 有状态组件 页面上绑定数据、改变页面数据
一.Flutter 中自定义有状态组件 在 Flutter 中自定义组件其实就是一个类,这个类需要继承 StatelessWidget/StatefulWidget. StatelessWidget ...
随机推荐
- SPOJ 4491
不妨先把所有要求的素数的对的个数写出来 f(2)=u(1)G(2)+u(2)*G(2*2)+u(3)*G(2*3)+.....u(k2)*G(2*k2) f(3)=u(1)G(3)+u(2)*G(2* ...
- webstorm卡顿问题处理
webstorm卡顿问题处理 学习了:http://blog.csdn.net/qq673318522/article/details/50583831 找到WebStorm.exe.vmoption ...
- [Angular] Set Metadata in HTTP Headers with Angular HttpHeaders
Besides sending (or requesting) the actual data to the server API, there’s also often the need to se ...
- grep常见使用方法总结
grep -E 'l\{2,\}' 2.txt grep -E 'h(ell|a)o' test.txt grep '[a-z]\{5,\}' test.txt grep -xf a.txt b.tx ...
- java Semaphore信号亮-同意多个任务同一时候訪问这个资源--thinking in java21.7.6
package org.rui.thread.newc.semaphore; import java.util.ArrayList; import java.util.List; import jav ...
- Spring25大面试题
1.什么是Spring框架?Spring框架有哪些主要模块? Spring框架是一个为Java应用程序的开发提供了综合.广泛的基础性支持的Java平台.Spring帮助开发人员攻克了开发中基础性的问题 ...
- poj1363——Rails
Description There is a famous railway station in PopPush City. Country there is incredibly hilly. Th ...
- (转载) Android开发时,那些相见恨晚的工具或网站!
huangmindong的专栏 目录视图 摘要视图 订阅 赠书 | 异步2周年,技术图书免费选 程序员8月书讯 项目管理+代码托管+文档协作,开发更流畅 Android ...
- swift语言点评十-Value and Reference Types
结论:value是拷贝,Reference是引用 Value and Reference Types Types in Swift fall into one of two categories: f ...
- SpringBoot学习笔记(3)----SpringBoot的profile多环境配置
在实际的应用开发中,可能会需要不同配置文件来支撑程序的运行,如开发,测试,预生产,生产环境等,程序在不同的环境下可能需要不同的配置,如不同数据源等,如果每次在不同的环境下都要去修改配置文件就会闲得不合 ...