vector找最大值 最小值

来源:互联网 发布:php 金额 格式化 编辑:程序博客网 时间:2024/05/22 03:51

参考别人的代码:

#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;
 
struct VectorPred
{
    bool operator()(const vector<int>& lhs, const vector<int>& rhs)
    {
        return *max_element(lhs.begin(), lhs.end()) < *max_element(rhs.begin(), rhs.end());
    }
};
 
int main()
{
    int testArray1[5] = {3, 6, 8, 2, 1};
    int testArray2[5] = {3, 6, 8, 10, 1};
    int testArray3[5] = {1, 6, 8, 2, 100};
 
    vector<int> vec1(testArray1, testArray1 + 5);
    vector<int> vec2(testArray2, testArray2 + 5);
    vector<int> vec3(testArray3, testArray3 + 5);
 
    vector<vector<int> > testData;
    testData.push_back(vec1);
    testData.push_back(vec2);
    testData.push_back(vec3);
 
    vector<vector<int> >::iterator maxIt = max_element(testData.begin(), testData.end(), VectorPred());
    int maxElement = *max_element(maxIt->begin(), maxIt->end());
 
    cout << maxElement << endl;
}

自己的代码:

struct VectorPred
{
bool operator()(const vector<int>& lhs, const vector<int>& rhs)
{
return *max_element(lhs.begin(), lhs.end()) < *max_element(rhs.begin(), rhs.end());
}
};
struct VectorPred2
{
bool operator()(const vector<int>& lhs, const vector<int>& rhs)
{
return *min_element(lhs.begin(), lhs.end()) < *min_element(rhs.begin(), rhs.end());
}
};
vector<vector<int> >::iterator maxIt = max_element(tp.begin(), tp.end(), VectorPred());
double maxElement = *max_element(maxIt->begin(), maxIt->end());
maxElement = maxElement / 255;
if (maxElement>0.99)
maxElement = 0.99;
cout <<"maxElement"<< maxElement << endl;


vector<vector<int> >::iterator minIt = min_element(tp.begin(), tp.end(), VectorPred2());
double minElement = *min_element(minIt->begin(), minIt->end());
minElement = (minElement / 255.0);
if (minElement<0.001)
minElement = 0.001;
cout <<"minElement"<< minElement << endl;

0 0
原创粉丝点击