#include #include #include #include using namespace std; const double eps = 1e-6; #define Equal(a, b) ((fabs(a - b) < eps) ? true : false) struct P { double x, y, z; // 坐标 double dx, dy, dz; // 方向 bool isend; // 是否为端点 int type; // 0卡箍 1未确定分支点 2已确定分支点 3连接器 int ref; // 指向其代表的相应数据类型标号 bool operator<(P B) const; bool operator==(P B) const; bool operator!=(P B) const; void set(int i, double v); const double get(int i); void reverse(); P(double x1, double y1, double z1); P(); P operator-(P B) const; P operator+(P B) const; P operator*(double p) const; P operator/(double p) const; void print(string s); // 设置方向 void setDir(const P &dir); };