day68(1.27)——leetcode面试经典150

149. 直线上最多的点数

149. 直线上最多的点数

题目:

题解:

java 复制代码
class Solution {
    public int maxPoints(int[][] points) {
        if(points.length <= 2) {
            return points.length;
        }
        int n=points.length;
        int max_sum = 0;
        for(int i=0;i<points.length;i++) {
            for(int j=i+1;j<points.length;j++) {
                int count = 2;
                int x1 = points[i][0];
                int y1 = points[i][1];
                int x2 = points[j][0];
                int y2 = points[j][1];
                if (x1 == x2) {
                // 垂直线
                    for (int k = 0; k < n; k++) {
                        if (k != i && k != j && points[k][0] == x1) {
                            count++;
                        }
                    }
                } else if (y1 == y2) {
                    // 水平线
                    for (int k = 0; k < n; k++) {
                        if (k != i && k != j && points[k][1] == y1) {
                            count++;
                        }
                    }
                } else {
                    // 斜线
                    double k_val = 1.0 * (y2 - y1) / (x2 - x1);
                    double b_val = y1 - k_val * x1;
                    for (int k = 0; k < n; k++) {
                        if (k != i && k != j) {
                            double y_pred = k_val * points[k][0] + b_val;
                            if (Math.abs(y_pred - points[k][1]) < 1e-6) {
                                count++;
                            }
                        }
                    }
                }
                max_sum = Math.max(max_sum, count);
            }
        }
        return max_sum;
    }
}
相关推荐
似水明俊德1 天前
01-C#.Net-泛型-面试题
java·开发语言·面试·c#·.net
独自破碎E1 天前
前后端分离+微服务架构下的用户认证
java·面试·架构
发现一只大呆瓜1 天前
Vue-Vue2与Vue3核心差异与进化
前端·vue.js·面试
Byron__1 天前
HashMap面试知识点
java·面试·hash
发现一只大呆瓜1 天前
Vue2:数组/对象操作避坑大全
前端·vue.js·面试
发现一只大呆瓜1 天前
Vue3:ref 与 reactive 超全对比
前端·vue.js·面试
victory04311 天前
Agent 面试知识树 + 高频追问答案库
网络·面试·职场和发展
swipe1 天前
JavaScript 对象操作进阶:从属性描述符到对象创建模式
前端·javascript·面试
星辰_mya1 天前
ZooKeeper 分布式锁:强一致性下的“排队”哲学
分布式·zookeeper·云原生·面试·分布式锁