ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

leetcode 1232. Check If It Is a Straight Line(python)

2021-09-04 15:01:44  阅读:179  来源: 互联网

标签:直线 return 1232 python Straight coordinates 斜率 True Check


描述

You are given an array coordinates, coordinates[i] = [x, y], where [x, y] represents the coordinate of a point. Check if these points make a straight line in the XY plane.

Example 1:

Input: coordinates = [[1,2],[2,3],[3,4],[4,5],[5,6],[6,7]]
Output: true

Example 2:

Input: coordinates = [[1,1],[2,2],[3,4],[4,5],[5,6],[7,7]]
Output: false

Note:

2 <= coordinates.length <= 1000
coordinates[i].length == 2
-10^4 <= coordinates[i][0], coordinates[i][1] <= 10^4
coordinates contains no duplicate point.

解析

根据题意,就是判断坐标系中给出的点是不是都在一条直线上,如果 coordinates 中只有两个点直接返回 True ,因为平面中的两个点肯定在一条直线上。

如果有多个点,先计算出前两个点组成直线的斜率 p ,然后从第三个点开始遍历,计算它与第二点组成的直线的斜率是否和 p 相等,如果不等则直接返回 False ;

接着判断第四个点与第三个点组成的直线的斜率是否和 p 相等,如果不等则直接返回 False ,以此类推,如果遍历结束都在一条直线上返回 True 。

【注意】计算斜率的时候,当两个点的 y 都相等的时候斜率为 0,当两个点的 x 相等的时候斜率为一个大数,其他情况直接出斜率即可。另外程序中判断小数是否相等需要用到 abs(a-b) > 0.0001 。

解答

class Solution(object):
    def checkStraightLine(self, coordinates):
        """
        :type coordinates: List[List[int]]
        :rtype: bool
        """
        if len(coordinates)==2:
            return True
        def cal_slope(p1, p2):
            x, y = p1[0], p1[1]
            x_, y_ = p2[0], p2[1]
            deltay = y_ - y
            deltax = x_ - x
            if deltax == 0:
                return float("inf")
            elif deltay == 0:
                return 0
            else:
                return deltay/deltax
        p = cal_slope(coordinates[0], coordinates[1])
        for i in range(2,len(coordinates)):
            tmp = cal_slope(coordinates[i-1], coordinates[i])
            if abs(tmp- p) > 0.0001:
                return False
        return True

运行结果

Runtime: 32 ms, faster than 100.00% of Python online submissions for Check If It Is a Straight Line.
Memory Usage: 13.8 MB, less than 73.10% of Python online submissions for Check If It Is a Straight Line.

原题链接:https://leetcode.com/problems/check-if-it-is-a-straight-line/

您的支持是我最大的动力

标签:直线,return,1232,python,Straight,coordinates,斜率,True,Check
来源: https://blog.csdn.net/wang7075202/article/details/120100054

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

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

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

ICode9版权所有