Computer >> Máy Tính >  >> Lập trình >> C ++

Chương trình C ++ áp dụng kiểm tra từ trên xuống dưới để tìm vị trí của một điểm đối với một đường

Đây là một chương trình C ++ áp dụng Kiểm tra Trên-Dưới-trên để tìm vị trí của một điểm đối với một Đường. Đối với bất kỳ điểm t (xt, yt) nào trên mặt phẳng, vị trí của nó đối với đoạn thẳng L nối m và n được tìm thấy bằng cách tính toán vô hướng s -

Y = A xt + B yt + C

Nếu Y <0, t nằm trong nửa mặt phẳng theo chiều kim đồng hồ của L; nếu Y> 0, t nằm trên nửa mặt phẳng ngược chiều kim đồng hồ; nếu Y =0, t nằm trên L.

Thuật toán

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

Mã mẫu

#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;
}

Đầu ra

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