在C++中将一个向量与另一个向量一起排序
Sorting a vector alongside another vector in C++
我正在C++中编写一个函数,它将接受两个称为xvalues和yvalues的二重向量。我的目标是用这些输入创建插值。然而,如果对(x,y)对进行排序,使得x值按递增顺序排列,并且y值仍然与正确的x值相对应,则会非常方便。
有人知道我如何有效地做到这一点吗?
我可能会创建一个成对的向量,并通过任何必要的方式对其进行排序。
这听起来像是您的数据抽象(实际"链接"的值的两个单独集合是错误的)。
作为一种替代方案,您可以编写某种迭代器适配器,它在内部容纳两个迭代器,并同时增加/减少/分配它们。它们取消引用一种特殊类型,该类型在交换时交换两个向量中的两个值,但在比较时只比较一个。这可能是一些工作(额外的交换,操作<,类),但当作为模板完成时,并且您更经常需要这样做,可能会得到回报。
或者使用对的向量,然后可以使用stl排序算法轻松排序,或者编写自己的排序方法。因此,您有几个选择。在您自己的排序算法中,您不仅可以对x向量进行排序,还可以分别对y向量进行排序。
这里是对两个向量(vec1
和vec2
)使用冒泡排序的示例。
bool bDone = false;
while (!done) {
done = true;
for(unsigned int i=0; i<=vec1.size()-1; ++i) {
if ( vec1.at(i) > vec1.at(i+1) ) {
double tmp = vec1.at(i);
vec1.at(i) = vec1.at(i+1);
vec1.at(i+1) = tmp;
tmp = vec2.at(i);
vec2.at(i) = vec2.at(i+1);
vec2.at(i+1) = tmp;
done = false;
}
}
}
但是,正如其他人在这里指出的那样,您应该谨慎地使用std::vector< std::pair<double, double> >
并对其进行排序。
这个想法很简单:实现一个排序算法(例如,quicksort很容易,在大多数用例中简称为OK)-有很多可用的实现:http://www.java-samples.com/showtutorial.php?tutorialid=445)。
- 对你的x向量进行比较
- 对两个矢量进行交换
排序方法必须将两个向量都作为输入,但这应该是一个小问题。
相关文章:
- 函数向量_指针有不同的原型,我可以构建一个吗
- C++从另一个类访问公共静态向量的正确方法是什么
- 为什么我不能将一个对象push_back到属于另一个类的对象向量中?
- 给定一个向量,如何找到该向量的所有子集和的原始索引
- 获取向量C++中第一个值和最后一个值的和
- 从多个源构造一个对象,包括一个对象向量
- 为什么一个向量上的多线程操作很慢
- 基于范围的 for 循环:迭代使用一个元素扩展的向量
- C++ - 如何在结构向量中找到结构体一个成员的最大值?
- 如何在 C++11 中查找和更新向量中的一个嵌套结构
- Lower_bound不适用于具有 3 个元素的向量的最后一个元素
- 将一个向量插入另一个向量的某个位置
- std::find,返回所有找到的值的替代方法,而不仅仅是存在重复的向量的第一个值
- 将指向给定子类的指针从一个向量复制到另一个向量
- 如何创建一个类,以便向量工作 std::vector<MyClass<int>> v{ 1,2,3 };
- C++ STD 函数运算符:有没有一种方法可以通过函数将一个向量映射到另一个向量上?
- 将向量之间的数字放在另一个向量之间<vector>>如果两个数字的差值为 1
- 如何在不复制的情况下将一个向量移动到另一个向量中
- 创建一个函数的 Python 绑定,返回指向带有 boost 的向量的指针
- 紧凑向量一个小的内存足迹向量