当前位置:网站首页>149. The largest number on a straight line, and check the set

149. The largest number on a straight line, and check the set

2022-08-03 19:41:00 Mr Gao

给你一个数组 points ,其中 points[i] = [xi, yi] 表示 X-Y 平面上的一个点.求最多有多少个点在同一条直线上.

示例 1:

输入:points = [[1,1],[2,2],[3,3]]
输出:3

在这里插入图片描述

示例 2:

输入:points = [[1,1],[3,2],[5,3],[4,1],[2,3],[1,4]]
输出:4

在这里插入图片描述
The blogger is also the first time to use the method of concatenating collections,I think it's really amazing,This method should solve many difficult problems,But to use it requires us to do some more applications:

解题代码如下:


int find(int x,int *p){
    
    while(x!=p[x]){
    
        x=p[x];
    }
    return x;
}



int maxPoints(int** points, int pointsSize, int* pointsColSize){
    
    int p[pointsSize];
    int i,j;
    int max=0;
    int cei[pointsSize][2];
    for(i=0;i<pointsSize;i++){
    
        printf("||");
      
        int  cur=0;
        for(j=i+1;j<pointsSize;j++){
    
             
            cei[cur][0]=points[i][0]-points[j][0];
             cei[cur][1]=points[i][1]-points[j][1];
            cur++;

        }
  // printf("cur %d |",cur);
        int hash[pointsSize];
           for(j=0;j<cur;j++){
    
     
                   p[j]=j;
            }

        

        for(j=0;j<cur;j++){
    

            hash[j]=0;

            for(int k=j+1;k<cur;k++){
    
                if(cei[k][0]*cei[j][1]-cei[k][1]*cei[j][0]==0){
    
                    
                    p[k]=j;

                }
            }
        }
         for(j=0;j<cur;j++){
    
           
             max=fmax(max,++hash[find(j,p)]);
           // printf("%d %d |",find(j,p),hash[find(j,p)]);
         }



    }
    printf("max %d ",max);
    return max+1;
}
原网站

版权声明
本文为[Mr Gao]所创,转载请带上原文链接,感谢
https://yzsam.com/2022/215/202208031936269413.html