lintcode-medium-Max Points on a Line
Posted 哥布林工程师
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了lintcode-medium-Max Points on a Line相关的知识,希望对你有一定的参考价值。
Given n points on a 2D plane, find the maximum number of points that lie on the same straight line.
Example
Given 4 points: (1,2)
, (3,6)
, (0,0)
, (1,3)
.
The maximum number is 3
.
/** * Definition for a point. * class Point { * int x; * int y; * Point() { x = 0; y = 0; } * Point(int a, int b) { x = a; y = b; } * } */ public class Solution { /** * @param points an array of point * @return an integer */ public int maxPoints(Point[] points) { // Write your code here if(points == null || points.length == 0) return 0; int result = 0; HashMap<Double, Integer> map = new HashMap<Double, Integer>(); for(int i = 0; i < points.length; i++){ int dup = 1; int ver = 0; for(int j = i + 1; j < points.length; j++){ if(points[i].x == points[j].x){ if(points[i].y == points[j].y) dup++; else ver++; } else{ double slope = (double)(points[j].y - points[i].y) / (double)(points[j].x - points[i].x); if(map.containsKey(slope)) map.put(slope, map.get(slope) + 1); else map.put(slope, 1); } } int count = 0; for(Map.Entry<Double, Integer> entry: map.entrySet()){ if(entry.getValue() > count) count = entry.getValue(); } result = Math.max(result, count + dup); result = Math.max(result, ver + dup); map.clear(); } return result; } }
以上是关于lintcode-medium-Max Points on a Line的主要内容,如果未能解决你的问题,请参考以下文章
Limit point, Accumulation point, and Condensation point of a set
用java怎么从字母加数字的string中提取数字,是有规律的string,如point1,point2,point3
MFC中画直线CDC::LineTo(POINT point)这个函数使用的疑问???
确定一个 POINT 是不是位于 LINESTRING 上的两个其他 POINT 之间(SQL Server 2008 Geography)