首页 > 其他 > 详细

Problem Max Points On a Line

时间:2014-07-07 16:54:20      阅读:345      评论:0      收藏:0      [点我收藏+]

Problem Description:

Given n points on a 2D plane, find the maximum number of points that lie on the same straight line.

Solution:

 1   public int maxPoints(Point[] points) {
 2      if (points.length <= 1) {
 3             return points.length;
 4         }
 5         Map<Double, Integer> map = new HashMap<Double, Integer>();
 6         int maxPoints = 0;
 7         for (int i = 0; i < points.length; i++) {
 8             map.clear();
 9             int samePointCount = 1;
10             int max = 0;
11             for (int j = i+1; j < points.length; j++) {
12                 if (points[i].x == points[j].x &&
13                     points[i].y == points[j].y) {
14                     samePointCount++;
15                 } else {
16                     double slope = Double.MAX_VALUE;
17                     if (points[i].y == points[j].y) {
18                         slope = 0;
19                     }
20                     else if (points[i].x != points[j].x) 
21                         slope = (points[i].y - points[j].y) / (double) (points[i].x - points[j].x);
22                     if (! map.containsKey(slope)) {
23                         map.put(slope, 1);
24                     } else {
25                         map.put(slope, map.get(slope)+1);
26                     }
27                 
28                     if (map.get(slope) > max) {
29                         max = map.get(slope);
30                     }
31                     
32                 }
33             }
34             if (max + samePointCount  > maxPoints) {
35                 maxPoints = max + samePointCount ;
36             }
37         }
38         return maxPoints;
39 
40     }

 

Problem Max Points On a Line,布布扣,bubuko.com

Problem Max Points On a Line

原文:http://www.cnblogs.com/liew/p/3815008.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!