Cat*_*kul 4 c++ sorting boost stl
例如,我想找到向量的排序顺序,而无需重新排序向量。
我可以想到几种方法来做到这一点,我想知道我是否缺少一些内置的 STL 或 BOOST 方法来做到这一点。
我想如果功能可用,代码最终会看起来像这样:
std::vector<float> unsortedSeq;
unsortedSeq.push_back( 1.1 );
unsortedSeq.push_back( 1.0 );
unsortedSeq.push_back( 0.5 );
unsortedSeq.push_back( 1.2 );
unsortedSeq.push_back( 1.15 );
std::list<std::size_t> sortOrder;
std::sort_indices( unsortedSeq.begin(), unsortedSeq.end(), sortOrder.begin() );
BOOST_FOREACH( std::size_t index, sortOrder )
{
std::cout << index << "\n"
}
2
1
0
4
3
Run Code Online (Sandbox Code Playgroud)
任何人都知道任何 STL 或 BOOST-sims 会像我所问的那样简单地完成我的要求?
std::vector<float> v;
// filled somewhere else
std::vector<std::size_t> indices(v.size());
// iota is from <numeric>, C++0x
std::iota(indices.begin(), indices.end(), 0);
std::sort(indices.begin(), indices.end(), [&v](std::size_t left, std::size_t right)
{
return v[left] < v[right];
});
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
2599 次 |
| 最近记录: |