Đây là một chương trình C ++ để kiểm tra xem một bộ ba điểm nhất định có nằm trên một dòng hay không. Ba điểm nằm trên một đường thẳng nếu diện tích của tam giác do các điểm này tạo thành bằng không.
Diện tích của tam giác là -
0.5 * (x1 * (y2 - y3) + x2 * (y3 - y1) + x3 * (y1 - y2)).
Thuật toán
Begin Generate the points randomly. Calculate the area by using above formula. If area > 0 Then the points don't lie on the straight line. else if area < 0 Then the points don't lie on the straight line. else The points lie on the straight line. End
Ví dụ
#include <iostream> #include <time.h> #include <stdlib.h> using namespace std; static int L = 1; static int U= 20; int main(int argc, char **argv) { int x3, y3, x1, x2, y1, y2; time_t seconds; time(&seconds); srand((unsigned int) seconds); //Generate the points randomly using rand(). x1 = rand() % ( U- L+ 1) + L; y1 = rand() % (U - L+ 1) + L; x2 = rand() % (U - L + 1) + L; y2 = rand() % (U - L+ 1) + L; x3 = rand() % (U - L+ 1) + L; y3 = rand() % (U - L+ 1) + L; cout << "The points are: (" << x1 << ", " << y1 << "), (" << x2 << ", " << y2 << "), & (" << x3 << ", " << y3 << ")\n"; //calculate area float a = 0.5 *(x1 * (y2 - y3) + x2 * (y3 - y1) + x3 * (y1 - y2)); if (a < 0) cout << "The points don't lie on the straight line"; else if (a > 0) cout << "The points don't lie on the straight line "; else cout << "The points lie on the straight line"; }
Đầu ra
The points are: (20, 9), (6, 13), & (13, 11) The points lie on the straight line The points are: (9, 15), (4, 15), & (11, 16) The points don't lie on the straight line