通过此向量中的地图成员对对象矢量进行排序

时间:2018-06-04 22:49:34

标签: algorithm c++11 vector stl

我猜的是一个非常简单的问题,但...... 我必须通过它自己的成员对矢量进行排序,但我不能。

这是我用另一个向量填充向量的函数。 我必须按特定产品对VectorDealers进行排序,但我不知道如何将Stock的名称发送给我的重载运算符<

void CShop::sortVector(const CStock& s1)
{
    vector<CDealer> SortDealers;
    vector<CDealer* >::iterator it = Dealers.begin();
    while (it != Dealers.end())
    {
        if ((*(*it)).ComapareNameProducts(s1))
        {
            SortDealers.push_back(*(*it));
        }
        it++;

    }
    sort(SortDealers.begin(), SortDealers.end());
    copy(SortDealers.begin(), SortDealers.end(), ostream_iterator<CDealer>(cout, "\n"));
} 

这是重载运算符&lt;: 我必须按地图的未签名成员排序。

bool CDealer::operator<(const CDealer & o1)
{
    unsigned res1 = 0;
    unsigned res2= 0;
    map<const CStock, pair<unsigned, double>>::const_iterator it = Stock.begin();
    map<const CStock, pair<unsigned, double>>::const_iterator iter = o1.Stock.begin();
    while (it != Stock.end())
    {
        res1 += it->second.first;
        it++;
    }
    while (iter != o1.Stock.end())
    {
        res2 += iter->second.first;
        iter++;
    }
    return (res1 < res2);
}

1 个答案:

答案 0 :(得分:0)

您可以使用仿函数:

class less_than
{
    const string stockname;
    public:
    less_than(string s) : stockname(s) {}
    inline bool operator() const (const CDealer& a, const CDealer& b)
    {
        // use stockname here
    }
};

sort(SortDealers.begin(), SortDealers.end(), less_than("name"));

此外,您可以使用lambda表达式在其捕获中提供股票名称。