当前位置:  开发笔记 > 编程语言 > 正文

比较矢量中的元素并返回对象的最佳方法

如何解决《比较矢量中的元素并返回对象的最佳方法》经验,为你挑选了1个好方法。

我有一个用例,其中数字在整数向量中单调递增

vec[0] = 2
vec[1] = 5
vec[2] = 8
vec[3] = 10
..

如果我通过了6号,我想返回vec [1],因为它位于vec [1]和vec [2]之间,类似地,如果pass 9必须返回vec [2].我对STL的经验是有限的,所以想检查一下我们可以用STL解决这个问题,或者你必须通过存储前一个来迭代每一个,当你点击一个大于你返回的传递数的数字时



1> bk1e..:

STL的具有四个可重用的二进制搜索算法头:lower_bound,upper_bound,equal_range,和binary_search.

lower_bound并不能完全按照您的意愿执行操作:当序列中不存在所需元素时,它返回一个迭代器,该迭代器引用一个超过所需元素的元素.但是,您应该能够使用实现您的行为的代码包装它而不会有太多麻烦.

推荐阅读
殉情放开那只小兔子
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有