首页 > 解决方案 > 使用python查找矩形的缺失坐标

问题描述

问题:给定一个矩形的三个顶点的整数坐标,其边平行于坐标轴,找到矩形的第四个顶点的坐标。

我已经编写了如下代码来回答问题(但它不正确):

coord_1_x = int(input())
coord_1_y = int(input())

coord_2_x = int(input())
coord_2_y = int(input())

coord_3_x = int(input())
coord_3_y = int(input())

coord_4_x = 0
coord_4_y = 0

if coord_1_x == coord_2_x:
  coord_4_x = coord_3_x
  if coord_2_y > coord_1_y:
    coord_4_y = coord_2_y
  else:
    coord_4_y = coord_1_y
else:
  if coord_3_x == coord_1_x:
    coord_4_x = coord_2_x
    coord_4_y = coord_3_y

print(coord_4_x)
print(coord_4_y)

以下是代码应显示的一些示例输入/输出:

示例输入 #1 - 给出的三个顶点是 (1, 5), (7, 5), (1, 10)

1
5
7
5
1
10

示例输出 #1

7
10

示例输入 #2 - 给出的三个顶点是 (1, 5), (7, 10), (1, 10)

1
5
7
10
1
10

示例输出 #2

7
5

请问有人可以帮我确定正确的代码来回答这个问题吗? (我试过谷歌搜索/阅读以前的 Stack 帖子,但找不到答案)

笔记。代码应该只使用 if/else 语句,而不是数组或循环

标签: pythonmathcoordinatesrectangles

解决方案


由于矩形是对称的,因此 X 和 Y 坐标需要在矩形的所有点中出现 2 次。因此,您只需要找到在给定点中出现一次的 X 和 Y 值:

def getMissingRectanglePoint(A, B, C):
    rectangle = [A, B, C]
    xValues = [p[0] for p in rectangle]
    yValues = [p[1] for p in rectangle]

    missingX = [mp for mp in xValues if xValues.count(mp) == 1][0]
    missingY = [mp for mp in yValues if yValues.count(mp) == 1][0]

    print missingX
    print missingY


getMissingRectanglePoint( (1, 5), (7, 5), (1, 10) )
getMissingRectanglePoint( (1, 5), (7, 10), (1, 10) )

印刷:

7
10

7
5

推荐阅读