cherrychenlee

导航

 

原文地址:https://www.jianshu.com/p/126cbb3d49f5

时间限制:1秒 空间限制:32768K

题目描述

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

我的代码

/**
 * Definition for a point.
 * struct Point {
 *     int x;
 *     int y;
 *     Point() : x(0), y(0) {}
 *     Point(int a, int b) : x(a), y(b) {}
 * };
 */
class Solution {
public:
    int maxPoints(vector<Point> &points) {
        int num=points.size();
        if(num<2)
            return num;
        int count=0;
        for(int i=0;i<num-1;i++){
            map<pair<int,int>,int> m;
            int cnt=0,numSame=0;
            for(int j=i+1;j<num;j++){
                if((points[i].x==points[j].x)
                   &&(points[i].y==points[j].y)){
                    ++numSame;continue;
                }
                int dx=points[i].x-points[j].x;
                int dy=points[i].y-points[j].y;
                int g=maxGYS(dx,dy);
                dx/=g;dy/=g;
                cnt=max(cnt,++m[make_pair(dx,dy)]);
            }
            count=max(count,cnt+numSame+1);
        }
        return count;
    }
    int maxGYS(int a,int b){
        if(b==0)
            return a;
        return maxGYS(b,a%b);
    }
};

运行时间:8ms
占用内存:360k

posted on 2019-05-08 14:06  cherrychenlee  阅读(106)  评论(0编辑  收藏  举报