ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

335. 路径交叉

2021-10-29 17:03:02  阅读:146  来源: 互联网

标签:distance return 交叉 335 路径 移动 True


给你一个整数数组 distance 。

从 X-Y 平面上的点 (0,0) 开始,先向北移动 distance[0] 米,然后向西移动 distance[1] 米,向南移动 distance[2] 米,向东移动 distance[3] 米,持续移动。也就是说,每次移动后你的方位会发生逆时针变化。

判断你所经过的路径是否相交。如果相交,返回 true ;否则,返回 false 。

class Solution:

    def isSelfCrossing(self, distance: List[int]) -> bool:

        n = len(distance)

        for i in range(3, n):

            # 第 1 类路径交叉的情况

            if (distance[i] >= distance[i - 2]

                    and distance[i - 1] <= distance[i - 3]):

                return True

            # 第 2 类路径交叉的情况

            if i == 4 and (distance[3] == distance[1]

                           and distance[4] >= distance[2] - distance[0]):

                return True

            # 第 3 类路径交叉的情况

            if i >= 5 and (distance[i - 3] - distance[i - 5] <= distance[i - 1] <= distance[i - 3]

                           and distance[i] >= distance[i - 2] - distance[i - 4]

                           and distance[i - 2] > distance[i - 4]):

                return True

        return False

标签:distance,return,交叉,335,路径,移动,True
来源: https://blog.csdn.net/weixin_43498998/article/details/121038599

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有