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;
    }
}
相关推荐
XH华2 小时前
备战蓝桥杯,第四章:数组
职场和发展·蓝桥杯
June bug3 小时前
【高频SQL基础版】查询
数据库·sql·面试·跳槽
程序员三藏10 小时前
接口测试及常用接口测试工具总结
自动化测试·软件测试·python·测试工具·职场和发展·测试用例·接口测试
码农水水13 小时前
中国邮政Java面试被问:容器镜像的多阶段构建和优化
java·linux·开发语言·数据库·mysql·面试·php
夏鹏今天学习了吗14 小时前
【LeetCode热题100(97/100)】二叉搜索树中第 K 小的元素
算法·leetcode·职场和发展
小桃酥ღ15 小时前
[力扣每日习题][1339]. 分裂二叉树的最大乘积 2026.01.07
算法·leetcode·职场和发展
闻哥15 小时前
Redis 避坑指南:从命令到主从的全链路踩坑实录
java·数据库·redis·缓存·面试·springboot
客卿12317 小时前
力扣20-有效括号(多家面试题)
算法·leetcode·职场和发展
阿拉伯柠檬19 小时前
网络层协议IP(三)
linux·网络·网络协议·tcp/ip·面试