网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
int main()
{
vector myvec{ 3, 2, 5, 7, 3, 2 };
vector lbvec(myvec);
sort(myvec.begin(), myvec.end(), cmp); // 旧式做法
cout << "predicate function:" << endl;
for (int it : myvec)
cout << it << ' ';
cout << endl;
sort(lbvec.begin(), lbvec.end(), [](int a, int b) -> bool { return a < b; }); // Lambda表达式
cout << "lambda expression:" << endl;
for (int it : lbvec)
cout << it << ' ';
}
旧式做法和lambda的做法功能是一样的.但lambda会更简单实现.
2.再来看一下<<视觉slam十四讲>>中的程序
float min_dis = std::min_element (
matches.begin(), matches.end(),
[] ( const cv::DMatch& m1, const cv::DMatch& m2 )
{
return m1.distance < m2.distance;
} )->distance;
其功能就是找到matches中最小的元素.
## 2. C++中min\_element()与max\_element()(取容器中的最大最小值)
**转载博客:https://www.cnblogs.com/ECJTUACM-873284962/p/6734225.html**
min\_element()和max\_element
头文件:#include<algorithm>
作用:返回容器中最小值和最大值。max\_element(first,end,cmp);其中cmp为可选择参数!
**注意:返回的是位置指针!**
写一个例子:
#include
#include
using namespace std;
bool cmp(int a,int b)
{
return a<b;
}
int main()
{
int num[]={2,3,1,6,4,5};
cout<<"最小值是 "<<*min_element(num,num+6)<<endl;
cout<<"最大值是 "<<*max_element(num,num+6)<<endl;
cout<<"最小值是 "<<*min_element(num,num+6,cmp)<<endl;
cout<<"最大值是 "<<*max_element(num,num+6,cmp)<<endl;
return 0;
}
## 3.综合使用如下例子
#include
#include
#include
#include
using namespace std;
int main()
{
vector myvec{3,2,5,6,7};
// sort(myvec.begin(),myvec.end(),[](int a,int b){return a<b;}
// );
// for(int it:myvec)
// {
// cout<<it<<endl;
// }
float val_min = *min_element(myvec.begin(),myvec.end(),[](int a,int b){return a<b;});
//float val_min = *max_element(myvec.begin(),myvec.end());
cout<<val_min<<endl;
}
![img](https://img-blog.csdnimg.cn/img_convert/13574bfad912c8d52009ef7195ff4337.png)
![img](https://img-blog.csdnimg.cn/img_convert/dd2651e0ee07761f2073f82351f02311.png)
**网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。**
**[需要这份系统化的资料的朋友,可以添加戳这里获取](https://bbs.csdn.net/topics/618668825)**
**一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**
/topics/618668825)**
**一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**