149. 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.

class Solution {
public:
    int maxPoints(vector<Point>& points) {
        unordered_map<float,int> mp;
        int maxNum = 0;
        for(int i=0;i<points.size();i++)
        {
            mp.clear();
            mp[INT_MAX] = 0; //當(dāng)只有一個(gè)元素時(shí),這個(gè)賦值有用
            int duplicate = 1;
            for(int j=0;j<points.size();j++)
            {
                if(j==i)
                  continue;
                if(points[i].x == points[j].x&&points[i].y == points[j].y)
                {
                    duplicate++;
                    continue;
                }
                float k = points[i].x == points[j].x ?  INT_MAX : (float)(points[i].y - points[j].y)/(points[i].x - points[j].x);
                mp[k]++;
 
            }
            unordered_map<float,int>::iterator it = mp.begin();
            for(;it!=mp.end();it++)
            {
              if(it->second + duplicate > maxNum)
                maxNum = it->second + duplicate;
            }
        }
        return maxNum;
    }
};
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容