利用python求矩形缺失坐标

问题描述 投票:0回答:3

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

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

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 语句,而不是数组或循环。

python math coordinates rectangles
3个回答
2
投票

由于矩形是对称的,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

0
投票
if coord1_x == coord2_x or coord1_x==coord3_x:
    if coord1_x == coord2_x:
           coord4_x=coord3_x
    else:
           coord4_x=coord2_x
else:
    coord4_x=coord1_x
if coord1_y == coord2_y or coord1_y==coord3_y:
    if coord1_y == coord2_y:
           coord4_y=coord3_y
    else:
           coord4_y=coord2_y
else:
    coord4_y=coord1_y

-1
投票
mylist = []
for i in range(6):
    num = input('num: ')
    mylist.append(num)
for i in range(2):
    if mylist.count(mylist[i]) == 2:
        number = ''.join(mylist[i])
        mylist.remove(number)
        mylist.remove(number)


print(mylist)
© www.soinside.com 2019 - 2024. All rights reserved.