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

     }
}

//这种从底层往上求的方式类似于动态规划里的打表法
相关推荐
岁岁的O泡奶15 分钟前
NSSCTF_crypto_[SWPU 2020]happy
经验分享·python·算法·密码学
EchoL、20 分钟前
【论文阅读】SteganoGAN:High Capacity Image Steganography with GANs
论文阅读·人工智能·笔记·算法
CoovallyAIHub21 分钟前
深度学习驱动的视频异常检测(VAD),AI如何让监控更智能?
深度学习·算法·计算机视觉
于樱花森上飞舞22 分钟前
【多线程】常见的锁策略与锁
java·开发语言·算法·java-ee
独自归家的兔27 分钟前
面试实录:三大核心问题深度拆解(三级缓存 + 工程规范 + 逻辑思维)
java·后端·面试·职场和发展
HUST27 分钟前
C 语言 第八讲:VS实用调试技巧
运维·c语言·开发语言·数据结构·算法·c#
历程里程碑36 分钟前
LeetCode128:哈希集合巧解最长连续序列
开发语言·数据结构·c++·算法·leetcode·哈希算法·散列表
@淡 定37 分钟前
Hash 索引与 B+树索引的区别与适用场景
b树·算法·哈希算法
Tzarevich37 分钟前
算法效率的核心:时间复杂度与空间复杂度
javascript·算法
没有故事的Zhang同学43 分钟前
03-📊 数据结构与算法核心知识 | 复杂度分析: 算法性能评估的理论与实践
算法