Trong phần này, chúng ta sẽ xem cách tạo lớp điểm bằng cách sử dụng lớp phức hợp từ STL trong C ++. Và áp dụng chúng vào một số bài toán liên quan đến hình học. Số phức có trong lớp phức từ STL (#include
Xác định lớp điểm
Để tạo phức thành điểm, chúng ta sẽ thay đổi tên của phức
# include <complex> typedef complex<double> point; # define x real() # define y imag()
Chúng tôi phải lưu ý rằng x và y đã được áp dụng dưới dạng macro, chúng không thể được áp dụng dưới dạng biến.
Ví dụ
Hãy cùng chúng tôi xem cách triển khai sau để hiểu rõ hơn -
#include <iostream> #include <complex> using namespace std; typedef complex<double> point; #define x real() #define y imag() int main() { point my_pt(4.0, 5.0); cout << "The point is :" << "(" << my_pt.x << ", " << my_pt.y << ")"; }
Đầu ra
The point is :(4, 5)
Để áp dụng hình học, chúng ta có thể thấy rằng khoảng cách của P từ điểm gốc (0, 0), được ký hiệu là −abs (P). Góc tạo bởi OP từ trục X với O là gốc:arg (z). Phép quay của P về gốc tọa độ là P * cực (r, θ).
Ví dụ
Hãy cùng chúng tôi xem cách triển khai sau để hiểu rõ hơn -
#include <iostream> #include <complex> #define PI 3.1415 using namespace std; typedef complex<double> point; #define x real() #define y imag() void print_point(point my_pt){ cout << "(" << my_pt.x << ", " << my_pt.y << ")"; } int main() { point my_pt(6.0, 7.0); cout << "The point is:" ; print_point(my_pt); cout << endl; cout << "Distance of the point from origin:" << abs(my_pt) << endl; cout << "Tangent angle made by OP with X-axis: (" << arg(my_pt) << ") rad = (" << arg(my_pt)*(180/PI) << ")" << endl; point rot_point = my_pt * polar(1.0, PI/2); cout << "Point after rotating 90 degrees counter-clockwise, will be: "; print_point(rot_point); }
Đầu ra
The point is:(6, 7) Distance of the point from origin:9.21954 Tangent angle made by OP with X-axis: (0.86217) rad = (49.4002) Point after rotating 90 degrees counter-clockwise, will be: (-6.99972, 6.00032)