蓝桥杯算法基础(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;
        }
     }

     }
}

//这种从底层往上求的方式类似于动态规划里的打表法
相关推荐
wclass-zhengge3 分钟前
数据结构篇(绪论)
java·数据结构·算法
何事驚慌3 分钟前
2024/10/5 数据结构打卡
java·数据结构·算法
结衣结衣.4 分钟前
C++ 类和对象的初步介绍
java·开发语言·数据结构·c++·笔记·学习·算法
大二转专业2 小时前
408算法题leetcode--第24天
考研·算法·leetcode
凭栏落花侧2 小时前
决策树:简单易懂的预测模型
人工智能·算法·决策树·机器学习·信息可视化·数据挖掘·数据分析
hong_zc3 小时前
算法【Java】—— 二叉树的深搜
java·算法
吱吱鼠叔4 小时前
MATLAB计算与建模常见函数:5.曲线拟合
算法·机器学习·matlab
嵌入式AI的盲5 小时前
数组指针和指针数组
数据结构·算法
Indigo_code8 小时前
【数据结构】【顺序表算法】 删除特定值
数据结构·算法
阿史大杯茶9 小时前
Codeforces Round 976 (Div. 2 ABCDE题)视频讲解
数据结构·c++·算法