LEETCODE | PYTHON | 1266 | 访问所有点的最小值

LEETCODE | PYTHON | 1266 | 访问所有点的最小值

1. 题目

平面上有 n 个点,点的位置用整数坐标表示 points[i] = [xi, yi] 。请你计算访问所有这些点需要的 最小时间(以秒为单位)。

你需要按照下面的规则在平面上移动:

每一秒内,你可以:
沿水平方向移动一个单位长度,或者
沿竖直方向移动一个单位长度,或者
跨过对角线移动 sqrt(2) 个单位长度(可以看作在一秒内向水平和竖直方向各移动一个单位长度)。
必须按照数组中出现的顺序来访问这些点。
在访问某个点时,可以经过该点后面出现的点,但经过的那些点不算作有效访问。

来源:力扣(LeetCode)
链接:https://leetcode.cn/problems/minimum-time-visiting-all-points
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

2. 代码

class Solution:
    def minTimeToVisitAllPoints(self, points: List[List[int]]) -> int:
        
        #中心思想:找到水平和垂直位置中较小的距离差,完成斜线移动,剩下的距离平行移动

        n = len(points)

        #特殊情况判断
        if n == 1:
            return 0
        
        #遍历判断
        res = 0

        #初始条件设置
        pos_x = points[0][0]
        pos_y = points[0][1]

        for i in range(1,n):

            #确定目标节点位置
            x = points[i][0]
            y = points[i][1]

            #比较水平与垂直距离的大小
            horizon = abs(pos_x-x)
            vertical = abs(pos_y-y)

            #较小值作为斜线移动值
            res = res + min(horizon,vertical)

            #剩余值利用平行移动补齐
            res = res + abs(horizon-vertical)

            #更新基准点的位置
            pos_x, pos_y = x, y

        return res

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值