0149:直线上最多的点数(★★)
目录
题目
给你一个数组 points
,其中 points[i] = [xi, yi]
表示 X-Y 平面上的一个点。求最多有多少个点在同一条直线上。
示例 1:
输入:points = [[1,1],[2,2],[3,3]] 输出:3
示例 2:
输入:points = [[1,1],[3,2],[5,3],[4,1],[2,3],[1,4]] 输出:4
提示:
1 <= points.length <= 300
points[i].length == 2
-104 <= xi, yi <= 104
points
中的所有点 互不相同
相似问题:
分析
- 本题可能有重复点,因此考虑按点遍历更方便:
- 对于每个点,首先统计重复个数 same
- 然后将其它点按斜率分组
- 最大的组大小加上 same 即可
- 考虑到精度问题,可以用最简分数来表示斜率,注意不存在斜率的特殊情况
解答
|
|
212 ms