เป็นโปรแกรม C++ สำหรับใช้ Above-Below-on Test เพื่อค้นหาตำแหน่งของจุดที่สัมพันธ์กับเส้น สำหรับจุด t (xt, yt) ใดๆ บนระนาบ ตำแหน่งของมันเทียบกับเส้น L ที่เชื่อมต่อ m และ n หาได้จากการคำนวณสเกลาร์ s -
Y = A xt + B yt + C
ถ้า Y<0 t อยู่ใน halfplane ตามเข็มนาฬิกาของ L; ถ้า Y>0, t อยู่บน halfplane ทวนเข็มนาฬิกา; ถ้า Y=0, เสื้ออยู่บน L.
อัลกอริทึม
Begin Take the points as input. For generating equation of the line, generate random numbers for coefficient of x and y (x1,x2,y1,y2) by using rand function at every time of compilation. Compute s as (y2 - y1) * x + (x1 - x2) * y + (x2 * y1 - x1 * y2). if (s < 0) Print "The point lies below the line or left side of the line". else if (s >0) print "The point lies above the line or right side of the line"; else print "The point lies on the line" End
โค้ดตัวอย่าง
#include<stdlib.h> #include<iostream> #include<math.h> #include<time.h> using namespace std; const int L = 0; const int H= 20; int main(int argc, char **argv) { time_t seconds; time(&seconds); srand((unsigned int) seconds); int x1, x2, y1, y2; x1 = rand() % (H - L + 1) + L; x2 = rand() % (H - L + 1) + L; y1 = rand() % (H - L + 1) + L; y2 = rand() % (H - L + 1) + L; cout << "The Equation of the 1st line is : (" << (y2 - y1) << ")x+(" << (x1 - x2) << ")y+(" << (x2 * y1 - x1 * y2) << ") = 0\n"; int x, y; cout << "\nEnter the point:"; cin >>x; cin >>y; int s = (y2 - y1) * x + (x1 - x2) * y + (x2 * y1 - x1 * y2); if (s < 0) cout << "The point lies below the line or left side of the line"; else if (s >0) cout << "The point lies above the line or right side of the line"; else cout << "The point lies on the line"; return 0; }
ผลลัพธ์
The Equation of the 1st line is : (7)x+(0)y+(-105) = 0 Enter the point:7 6 The point lies below the line or left side of the line