gpt4 book ai didi

c++ - 在 vector 中找到 n 个最大值

转载 作者:太空宇宙 更新时间:2023-11-04 15:21:12 25 4
gpt4 key购买 nike

我目前有一个 vector ,需要在其中找到 n 个最大的数字。例如,用户输入 5,我必须遍历它并输出最大的 5 个。问题是,由于其他限制,我无法对这个 vector 进行排序。解决此问题的最佳方法是什么?

谢谢!

最佳答案

根据您关于不修改原始 vector 的描述以及我认为您希望顺序重要的假设,我建议 std::partial_sort_copy :

//assume vector<int> as source
std::vector<int> dest(n); //largest n numbers; VLA or std::dynarray in C++14
std::partial_sort_copy(
std::begin(source), std::end(source), //.begin/.end in C++98/C++03
std::begin(dest), std::end(dest),
std::greater<int>() //remove "int" in C++14
);
//output dest however you want, e.g., std::copy

关于c++ - 在 vector 中找到 n 个最大值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18807792/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com