久久久久久久av_日韩在线中文_看一级毛片视频_日本精品二区_成人深夜福利视频_武道仙尊动漫在线观看

如何通過不同 std::vector 的值對 std::vector 進行排序

How do I sort a std::vector by the values of a different std::vector?(如何通過不同 std::vector 的值對 std::vector 進行排序?)
本文介紹了如何通過不同 std::vector 的值對 std::vector 進行排序?的處理方法,對大家解決問題具有一定的參考價值,需要的朋友們下面隨著小編來一起學習吧!

問題描述

我有幾個 std::vector,長度都一樣.我想對這些向量之一進行排序,并對所有其他向量應用相同的轉換.有沒有一種巧妙的方法來做到這一點?(最好使用 STL 或 Boost)?一些向量包含 ints,其中一些包含 std::strings.

I have several std::vector, all of the same length. I want to sort one of these vectors, and apply the same transformation to all of the other vectors. Is there a neat way of doing this? (preferably using the STL or Boost)? Some of the vectors hold ints and some of them std::strings.

偽代碼:

std::vector<int> Index = { 3, 1, 2 };
std::vector<std::string> Values = { "Third", "First", "Second" };

Transformation = sort(Index);
Index is now { 1, 2, 3};

... magic happens as Transformation is applied to Values ...
Values are now { "First", "Second", "Third" };

推薦答案

friol 的方法與您的方法結合使用時效果很好.首先,構建一個包含數字 1...n 的向量,以及向量中指示排序順序的元素:

friol's approach is good when coupled with yours. First, build a vector consisting of the numbers 1…n, along with the elements from the vector dictating the sorting order:

typedef vector<int>::const_iterator myiter;

vector<pair<size_t, myiter> > order(Index.size());

size_t n = 0;
for (myiter it = Index.begin(); it != Index.end(); ++it, ++n)
    order[n] = make_pair(n, it);

現在您可以使用自定義排序器對這個數組進行排序:

Now you can sort this array using a custom sorter:

struct ordering {
    bool operator ()(pair<size_t, myiter> const& a, pair<size_t, myiter> const& b) {
        return *(a.second) < *(b.second);
    }
};

sort(order.begin(), order.end(), ordering());

現在您已經捕獲了 order 中的重新排列順序(更準確地說,在項目的第一個組件中).您現在可以使用此順序對其他向量進行排序.可能有一個非常聰明的就地變體同時運行,但在其他人提出它之前,這里有一個不是就地變體.它使用 order 作為每個元素新索引的查找表.

Now you've captured the order of rearrangement inside order (more precisely, in the first component of the items). You can now use this ordering to sort your other vectors. There's probably a very clever in-place variant running in the same time, but until someone else comes up with it, here's one variant that isn't in-place. It uses order as a look-up table for the new index of each element.

template <typename T>
vector<T> sort_from_ref(
    vector<T> const& in,
    vector<pair<size_t, myiter> > const& reference
) {
    vector<T> ret(in.size());

    size_t const size = in.size();
    for (size_t i = 0; i < size; ++i)
        ret[i] = in[reference[i].first];

    return ret;
}

這篇關于如何通過不同 std::vector 的值對 std::vector 進行排序?的文章就介紹到這了,希望我們推薦的答案對大家有所幫助,也希望大家多多支持html5模板網!

【網站聲明】本站部分內容來源于互聯網,旨在幫助大家更快的解決問題,如果有圖片或者內容侵犯了您的權益,請聯系我們刪除處理,感謝您的支持!

相關文檔推薦

Assertion failed (size.widthgt;0 amp;amp; size.heightgt;0)(斷言失敗(size.width0 amp;amp; size.height0))
Rotate an image in C++ without using OpenCV functions(在 C++ 中旋轉圖像而不使用 OpenCV 函數)
OpenCV: process every frame(OpenCV:處理每一幀)
Why can#39;t I open avi video in openCV?(為什么我不能在 openCV 中打開 avi 視頻?)
OpenCV unable to set up SVM Parameters(OpenCV 無法設置 SVM 參數)
Convert a single color with cvtColor(使用 cvtColor 轉換單一顏色)
主站蜘蛛池模板: 五月婷婷在线视频 | 一区二区在线不卡 | 亚洲成色777777在线观看影院 | 国产永久免费 | 粉嫩在线 | 黄色亚洲网站 | 精品美女在线观看视频在线观看 | 精品亚洲一区二区三区四区五区高 | 国产成人亚洲精品自产在线 | 日本精品一区二区在线观看 | 97av视频| 91观看| 日日夜夜精品视频 | 日本精品在线一区 | 国产精品视频一区二区三区不卡 | 欧美视频在线免费 | 欧美亚洲国产一区二区三区 | 日韩欧美一区二区三区在线播放 | 久久国产高清 | 91精品国产91久久久久久吃药 | 国产精品美女久久久久久久久久久 | 亚洲成人毛片 | 成人av一区二区三区 | 香蕉婷婷 | 手机av在线 | 成年人黄色小视频 | 中文字幕日韩欧美一区二区三区 | 国产露脸对白88av | 欧美日韩精品久久久免费观看 | 日韩电影免费在线观看中文字幕 | 一区二区久久 | 亚洲精品视频在线看 | 夜夜爽99久久国产综合精品女不卡 | 欧美日韩一区二区在线观看 | 九九精品热 | 日韩久草| 日本福利视频免费观看 | 91av视频在线观看 | 欧美6一10sex性hd | 日本污视频 | 亚洲视频在线播放 |