解题思路:建立新的坐标系,转换坐标,判断距离
图中坐标只是表示每个六边形的相对位置,不要理解成几何中心的平面坐标!
注意事项:关键在于如何建一个坐标系使得方便判断距离
参考代码:
d1,p1,q1,d2,p2,q2 = map(int,input().split())
xdir = [-2,-1,1,2,1,-1] #六个基本方向的坐标(竖着看对应)
ydir= [0,1,1,0,-1,-1]
def switchloc(d,p,q):#坐标转换函数
x = xdir[d]*p + xdir[(d+2)%6]*q #此处妙啊
y = ydir[d]*p + ydir[(d+2)%6]*q
return x,y
x1,y1 = switchloc(d1,p1,q1)
x2,y2 = switchloc(d2,p2,q2)
x_abs,y_abs = abs(x1-x2),abs(y1-y2)
if x_abs >= y_abs:print((x_abs+y_abs)//2) #判断距离,坐标建得好条件就好判断
else:print(y_abs)
0.0分
1 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复