【发布时间】:2011-06-22 02:47:14
【问题描述】:
我有一个填充了一些顶点对象实例的向量,需要根据它的“x”和之后的“y”坐标对其进行排序。
顶点.h
#ifndef VERTEX_H
#define VERTEX_H 1
class Vertex
{
private:
double __x;
double __y;
public:
Vertex(const double x, const double y);
bool operator<(const Vertex &b) const;
double x(void);
double y(void);
};
#endif // VERTEX_H
顶点.cpp
#include "vertex.h"
Vertex::Vertex(const double x, const double y) : __x(x), __y(y)
{
}
bool Vertex::operator<(const Vertex &b) const
{
return __x < b.x() || (__x == b.x() && __y < b.y());
}
double Vertex::x(void)
{
return __x;
}
double Vertex::y(void)
{
return __y;
}
运行.cpp
#include <algorithm>
#include <stdio.h>
#include <vector>
#include "vertex.h"
void prnt(std::vector<Vertex *> list)
{
for(size_t i = 0; i < list.size(); i++)
printf("Vertex (x: %.2lf y: %.2lf)\n", list[i]->x(), list[i]->y());
}
int main(int argc, char **argv)
{
std::vector<Vertex *> list;
list.push_back(new Vertex(0, 0));
list.push_back(new Vertex(-3, 0.3));
list.push_back(new Vertex(-3, -0.1));
list.push_back(new Vertex(3.3, 0));
printf("Original:\n");
prnt(list);
printf("Sorted:\n");
std::sort(list.begin(), list.end());
prnt(list);
return 0;
}
我期望的输出是:
Original:
Vertex (x: 0.00 y: 0.00)
Vertex (x: -3.00 y: 0.30)
Vertex (x: -3.00 y: -0.10)
Vertex (x: 3.30 y: 0.00)
Sorted:
Vertex (x: -3.00 y: -0.10)
Vertex (x: -3.00 y: 0.30)
Vertex (x: 0.00 y: 0.00)
Vertex (x: 3.30 y: 0.00)
但我实际得到的是:
Original:
Vertex (x: 0.00 y: 0.00)
Vertex (x: -3.00 y: 0.30)
Vertex (x: -3.00 y: -0.10)
Vertex (x: 3.30 y: 0.00)
Sorted:
Vertex (x: 0.00 y: 0.00)
Vertex (x: -3.00 y: -0.10)
Vertex (x: -3.00 y: 0.30)
Vertex (x: 3.30 y: 0.00)
我不知道到底出了什么问题,有什么想法吗?
【问题讨论】:
-
如何编译?您的操作double Vertex::x() const?
-
请允许我欢迎您来到 StackOverflow,并提醒我们通常在这里做的三件事:1) 当您获得帮助时,请尝试在您的专业领域中回答问题 2)
Read the FAQs3)当你看到好的问答时,给他们投票using the gray triangles,因为系统的可信度是基于用户通过分享他们的知识而获得的声誉。还记得接受更好地解决您的问题的答案,如果有的话,by pressing the checkmark sign