给定两个数字 a 和 b,其中 b < a 形成一个带有点 (0, b), (b, 0), (ab, b), (b, ab) 的矩形。给定一个点 (x, y),任务是检查该点是否位于矩形内或矩形上。
例子:
Input: a = 7, b = 2, x = 5, y = 2;
Output: Given point does not lie on the rectangle
Input: a = 7, b = 2, x = 4, y = 5;
Output: Given point lies inside the rectangle
方法:一个有效的方法是形成一个矩形的四线方程。然后,如果给定点位于矩形内或矩形上当且仅当,将给定点代入:
- 右侧边线 ( xyb = 0 ) 必须给出小于或等于零的值。
- 左侧边线 ( x-y+a = 0 ) 必须给出大于或等于 1 的值。
- 上边线 ( x+y-2*a+b = 0 ) 必须给出小于或等于零的值。
- 下边线 ( x+yb = 0 ) 必须给出大于或等于 1 的值。
C++
// C++ program to Check whether a given point
// lies inside or on the rectangle or not
#include
using namespace std;
// function to Check whether a given point
// lies inside or on the rectangle or not
bool LiesInsieRectangle(int a, int b, int x, int y)
{
if (x - y - b <= 0 && x - y + b >= 0
&& x + y - 2 * a + b <= 0 && x + y - b >= 0)
return true;
return false;
}
// Driver code
int main()
{
int a = 7, b = 2, x = 4, y = 5;
if (LiesInsieRectangle(a, b, x, y))
cout << "Given point lies inside the rectangle";
else
cout << "Given point does not lie on the rectangle";
return 0;
}
Java
// Java program to Check whether
// a given point lies inside or
// on the rectangle or not
class GFG
{
// function to Check whether
// a given point lies inside
// or on the rectangle or not
static boolean LiesInsieRectangle(int a, int b,
int x, int y)
{
if (x - y - b <= 0 && x - y + b >= 0 &&
x + y - 2 * a + b <= 0 && x + y - b >= 0)
return true;
return false;
}
// Driver code
public static void main(String[] args)
{
int a = 7, b = 2, x = 4, y = 5;
if (LiesInsieRectangle(a, b, x, y))
System.out.println("Given point lies " +
"inside the rectangle");
else
System.out.println("Given point does not " +
"lie on the rectangle");
}
}
// This code is contributed
// by ChitraNayal
Python3
# Python 3 program to Check whether
# a given point lies inside or on
# the rectangle or not
# function to Check whether a given
# point lies inside or on the
# rectangle or not
def LiesInsieRectangle(a, b, x, y) :
if(x - y - b <= 0 and
x - y + b >= 0 and
x + y - 2 * a + b <= 0 and
x + y - b >= 0) :
return True
return False
# Driver code
if __name__ == "__main__" :
# multiple assignments
a, b, x, y = 7, 2, 4, 5
if LiesInsieRectangle(a, b, x, y) :
print("Given point lies inside"
" the rectangle")
else :
print("Given point does not lie"
" on the rectangle")
# This code is contributed by ANKITRAI1
C#
// C# program to Check whether
// a given point lies inside
// or on the rectangle or not
using System;
class GFG
{
// function to Check whether
// a given point lies inside
// or on the rectangle or not
static bool LiesInsieRectangle(int a, int b,
int x, int y)
{
if (x - y - b <= 0 &&
x - y + b >= 0 &&
x + y - 2 * a + b <= 0 &&
x + y - b >= 0)
return true;
return false;
}
// Driver code
public static void Main()
{
int a = 7, b = 2, x = 4, y = 5;
if (LiesInsieRectangle(a, b, x, y))
Console.Write("Given point lies " +
"inside the rectangle");
else
Console.Write("Given point does not " +
"lie on the rectangle");
}
}
// This code is contributed
// by ChitraNayal
PHP
= 0 &&
$x + $y - 2 * $a + $b <= 0 &&
$x + $y - $b >= 0)
return true;
return false;
}
// Driver code
$a = 7;
$b = 2;
$x = 4;
$y = 5;
if (LiesInsieRectangle($a, $b,
$x, $y))
echo "Given point lies ".
"inside the rectangle";
else
echo "Given point does not".
" lie on the rectangle";
// This code is contributed by mits
?>
Javascript
输出:
Given point lies inside the rectangle
如果您希望与专家一起参加现场课程,请参阅DSA 现场工作专业课程和学生竞争性编程现场课程。