蓝桥杯算法基础(25)边长为1的最大子方阵优化

复制代码
题4:边长为1的最大子方阵优化

预处理
对每个位置上为1的元素找右边下边有多少个1
1 1 1 0
1 1 0 1
1 1 0 1
0 1 1 1

3,3 2,4 1,0 0,0
2,2 1,3 0,0 1,3
2,1 1,2 0,0 1,2
0,0 3,1 2,1 1,1
(右,下)//算上自身


[3],[3] 2,[4]
[2], 2  1, 3
只需要看这四个数就可以确定一个正方形

//输出右下1个数的矩阵
private static void print(int[][][] rec,int N){
        for(int i=0;i<N;i++){

            for(int j=0;j<N;j++){
            System.out.print(rec[i][j][0]+","+rec[i][j][1]+"\t");
            }
            System.out.println();
        }
}
//全局变量
int[][][]res;//保存1右下个数的数组

//生成右边和下边的1的数量的数组
private static void generateHelpRec(int[][] A){
int N=A.length;
res=new int[N][N][2];
   //最后一行
 int row=N-1;

    //初始化最下面一层
    for(int j=N-1;j>=0;j--){
      int value=A[row][j];
      if(value==1){
        if(j==N-1)
      {rec[row][j][0]=1;}//右侧连接1的个数,最底层
      else
      {rec[row][j][0]=rec[row][j+1][0]+1;}

        res[row][j][1]=1;
      }

     }
     row--;
     for(int i=row;i>=0;i--){
      for(int j=N-1;j>=0;j--){
        int value=A[i][j];
        if(value==1){
            if(j==N-1)
            rec[i][j][0]=-1;
            else
            rec[i][j][0]=1=rec[i][j+1][0]+1;

            res[i][j][1]=res[i][j][1]+1;//向下连接的个数
        }
      }
     }

     return
}


//检查四条边是否正确
private static boolean check(int i,int j,int n){
       //左上角那个点往右数的1的数目要≥n
       //左上角那个点往下数的1的数目要≥n
       //右上角那个点往下数的1的数目要≥n
       //左下角那个点往右数的1的数目要≥n
       if(rec[i][j][0]>=n&&rec[i][j][1]>=n&&rec[i][j+n-1][1]>=n&&rec[i+n-1][j][0]>=n)
        return  true;
        return false;
}
private static int solve(int[][] A){
     int N=A.length;
     int n=N;
     while(n>0){
     for(int i=0;i<N;i++){
        l3;
        if(i+n>N)break;//越界
        for(int j=0;j<N;j++){

        if(j+n>N)break;//越界
        //检查四个边

        if(check(i,j,n))
        return n;
        }
     }

     }
}

//这种从底层往上求的方式类似于动态规划里的打表法
相关推荐
A.A呐30 分钟前
LeetCode 1658.将x减到0的最小操作数
算法·leetcode
hn小菜鸡32 分钟前
LeetCode 144.二叉树的前序遍历
算法·leetcode·职场和发展
rubyw37 分钟前
如何选择聚类算法、回归算法、分类算法?
算法·机器学习·分类·数据挖掘·回归·聚类
编程探索者小陈1 小时前
【优先算法】专题——双指针
数据结构·算法·leetcode
Sunyanhui11 小时前
力扣 三数之和-15
数据结构·算法·leetcode
Mr.kanglong1 小时前
【LeetCode热题100】队列+宽搜
算法·leetcode·职场和发展
sp_fyf_20241 小时前
计算机前沿技术-人工智能算法-大语言模型-最新研究进展-2024-11-05
人工智能·深度学习·神经网络·算法·机器学习·语言模型·数据挖掘
钰见梵星1 小时前
深度学习优化算法
人工智能·深度学习·算法
zzzhpzhpzzz2 小时前
设计模式——观察者模式
算法·观察者模式·设计模式
逸风尊者2 小时前
开发也能看懂的大模型:FNN
人工智能·后端·算法