在C++中實現二維向量的運算可以使用自定義的Vector2類來表示二維向量,然后重載運算符來實現各種向量運算操作。以下是一個簡單的例子:
#include <iostream>
class Vector2 {
public:
float x, y;
Vector2(float _x, float _y) : x(_x), y(_y) {}
Vector2 operator+(const Vector2& other) {
return Vector2(x + other.x, y + other.y);
}
Vector2 operator-(const Vector2& other) {
return Vector2(x - other.x, y - other.y);
}
float operator*(const Vector2& other) {
return x * other.x + y * other.y;
}
Vector2 operator*(float scalar) {
return Vector2(x * scalar, y * scalar);
}
Vector2 operator/(float scalar) {
return Vector2(x / scalar, y / scalar);
}
void print() {
std::cout << "(" << x << ", " << y << ")" << std::endl;
}
};
int main() {
Vector2 v1(1, 2);
Vector2 v2(3, 4);
Vector2 sum = v1 + v2;
Vector2 diff = v1 - v2;
float dot = v1 * v2;
Vector2 scalarMul = v1 * 2;
Vector2 scalarDiv = v2 / 2;
sum.print(); // Output: (4, 6)
diff.print(); // Output: (-2, -2)
std::cout << dot << std::endl; // Output: 11
scalarMul.print(); // Output: (2, 4)
scalarDiv.print(); // Output: (1.5, 2)
return 0;
}
在上面的例子中,我們定義了一個Vector2類來表示二維向量,然后重載了加減乘除等運算符來實現向量的加法、減法、點乘、標量乘法和標量除法等操作。通過重載運算符,我們可以使用自定義的Vector2類來進行向量運算,使得代碼更加直觀和易讀。