python - 使用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 语句,而不是数组或循环
解决方案
由于矩形是对称的,因此 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
推荐阅读
- html - 设置网站背景是google map iframe代码
- html - 更改 scss 中的悬停行为
- docker - 如何容器化应用程序的一部分
- android - android中的本地通知在设备重启时使用Alarmmanager
- python - Tensorflow 添加可见 gpu 设备:0
- azure - 权限不足,无法完成使用 az ad sp list 列出服务主体的操作
- docusignapi - 在 aws-amplify 应用程序中集成 docusign
- filter - 两个过滤行 Spotfire 之间的区别
- swift - 如何快速更新 messageCollectionView 单元格内的数据?
- python - Python3 TypeError:'value'必须是str或bytes的实例,而不是元组