如何将迭代器指向向量中大于或等于目标数的元素

Posted

技术标签:

【中文标题】如何将迭代器指向向量中大于或等于目标数的元素【英文标题】:How to point the iterator to an element in a vector which is greater than or equal to a target number 【发布时间】:2021-09-20 14:06:41 【问题描述】:

例如,我有一个向量 v=[7,4,5,10,13]。这里我的目标数字是 6。 我首先对向量进行排序:

sort(v.begin(), v.end());

现在我的输出将是 [4,5,7,10,13]。在此之后,我想打印大于或等于“6”的数字,这将使我输出为 [7,10,13]。

在 C++ 中执行此任务的便捷方式是什么?

【问题讨论】:

【参考方案1】:

使用std::upper_bound:

#include <algorithm>
#include <vector>
#include <iostream>

int main()

   std::vector<int> v = 7,4,5,10,13;
   std::sort(v.begin(), v.end());
   auto iter = std::upper_bound(v.begin(), v.end(), 6);
   for (; iter != v.end(); ++iter)
     std::cout << *iter << " ";

输出:

7 10 13

【讨论】:

lower_bound 为 >=,upper_bound 为 >【参考方案2】:

这是我的快速解决方案

std::vector<int> v = 7,4,5,10,13;
std::sort(v.begin(), v.end());
std::copy_if(v.begin(), v.end(), std::ostream_iterator<int>(std::cout, " "), 
[](int a) return a > 6;)

【讨论】:

【参考方案3】:

或者,如果您的编译器已经支持它,请使用

#include <algorithm>
#include <ranges>
#include <vector>
#include <iostream>

auto larger_then_6 = [](int i)  return i > 6; ;

int main()

    std::vector<int> v =  7,4,5,10,13 ;
    std::sort(v.begin(), v.end());

    for (auto value : v | std::views::filter(larger_then_6))
    
        std::cout << value << " ";
    

    std::cout << std::endl;

【讨论】:

以上是关于如何将迭代器指向向量中大于或等于目标数的元素的主要内容,如果未能解决你的问题,请参考以下文章

迭代器失效

迭代器在添加到添加到列表向量的结构中时会停止指向某个值吗?

关于向量、指针和迭代器的问题

如何将元素定义为与随机访问迭代器指向的元素相同的类型?

如何识别向量迭代器是不是已到达向量末尾?

如何理解lower_bound/upper_bound