class RankList {
public:
struct RankListComparator {
bool operator()(const std::pair<boost::numeric::ublas::vector<double>, double>& a, const std::pair<boost::numeric::ublas::vector<double>, double>& b) {
return a.second >= b.second;
}
};
void push_back(boost::numeric::ublas::vector<double> features, double label) {
m_list.push_back(std::pair<boost::numeric::ublas::vector<double>, double>(features, label));
}
void sort() {
std::sort(m_list.begin(), m_list.end(), RankListComparator());
}
protected:
std::vector<std::pair<boost::numeric::ublas::vector<double>, double> > m_list;
};
Что не так с сортировкой () выше?Я получаю:
terminate called after throwing an instance of 'std::bad_alloc'
what(): std::bad_alloc
при вызове sort ().GDB также не дает мне ничего полезного ...
Я предполагаю, что проблема связана с тем, что я учусь в классе?
РЕДАКТИРОВАТЬ: Решено
Theпроблема заключалась в том, что эта строка
return a.second >= b.second;
была изменена на
return a.second > b.second;