力扣面试150 直线上最多的点数 数学 直线斜率 欧几里得求最大公约数

Problem: 149. 直线上最多的点数

思路

👨‍🏫 参考题解

💖 枚举直线 + 枚举统计

时间复杂度: O ( n 3 ) O(n^3) O(n3)

空间复杂度: O ( 1 ) O(1) O(1)

Java 复制代码
class Solution {
	public int maxPoints(int[][] points)
	{
		int n = points.length;
		int ans = 1;
		for (int i = 0; i < n; i++)
		{
			int[] a = points[i];// 点1
			for (int j = i + 1; j < n; j++)
			{
				int[] b = points[j];// 点2
				int cnt = 2;
				for (int k = j + 1; k < n; k++)
				{
					int[] c = points[k];// 枚举其他的点
//					int s1 = (b[1] - a[1]) * (c[0] - b[0]);
//					int s2 = (c[1] - b[1]) * (b[0] - a[0]);
					int s1 = (a[1] - b[1]) * (b[0] - c[0]);
					int s2 = (a[0] - b[0]) * (b[1] - c[1]);
					if (s1 == s2)
						cnt++;
				}
				ans = Math.max(cnt, ans);
			}
		}
		return ans;
	}
}

枚举直线 + 哈希表统计


java 复制代码
class Solution {
//	枚举直线 + 哈希表统计
	public int maxPoints(int[][] points)
	{
		int n = points.length, ans = 1;
		for (int i = 0; i < n; i++)
		{
			Map<String, Integer> map = new HashMap<>();
			// 由当前点 i 发出的直线所经过的最多点数量
			int max = 0;
			int x1 = points[i][0], y1 = points[i][1];
			for (int j = i + 1; j < n; j++)
			{
				int x2 = points[j][0], y2 = points[j][1];
				int xx = x1 - x2, yy = y1 - y2;
				int k = gcd(xx, yy);// 最大公约数
				String key = (xx / k) + "_" + (yy / k);// 化简
				map.put(key, map.getOrDefault(key, 0) + 1);// key 是斜率,value 是数量
				max = Math.max(max, map.get(key));
			}
			ans = Math.max(ans, max + 1);
		}
		return ans;
	}
    //	求最大公约数
	int gcd(int a, int b)
	{
		return b == 0 ? a : gcd(b, a % b);
	}
}
相关推荐
爱写代码的小朋友7 分钟前
基于多约束遗传算法的中小学排座位优化模型研究
linux·人工智能·算法
один but you9 分钟前
unorder_map 和unorder_set
算法·哈希算法·散列表
jiayong2317 分钟前
前端面试题库 - JavaScript核心基础篇
前端·javascript·面试
JAVA面经实录91718 分钟前
Java多线程并发高频面试100题(完整版·含答案·背诵版)
java·开发语言·面试
sheeta199822 分钟前
LeetCode 每日一题笔记 日期:2026.05.20 题目:2657. 找到前缀公共数组
笔记·算法·leetcode
数智工坊38 分钟前
【UniT论文阅读】:用统一物理语言打通人类与人形机器人的知识壁垒
论文阅读·人工智能·深度学习·算法·机器人
梓䈑41 分钟前
【算法题攻略】模拟
c++·算法
Evand J43 分钟前
【课题推荐与代码介绍】卡尔曼滤波器正反向估计算法原理与MATLAB实现
开发语言·算法·matlab
DFT计算杂谈1 小时前
VASP新手入门: IVDW 色散修正参数
linux·运维·服务器·python·算法
吃着火锅x唱着歌1 小时前
LeetCode 962.最大宽度坡
算法·leetcode·职场和发展