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

题4:边长为1的最大子方阵优化预处理
对每个位置上为1的元素找右边下边有多少个1
1 1 1 0
1 1 0 1
1 1 0 1
0 1 1 13,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;elserec[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的数目要≥nif(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;}}}
}//这种从底层往上求的方式类似于动态规划里的打表法

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/755484.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【经验分享】Wubuntu------体验Windows和Ubuntu的结合体

【经验分享】Wubuntu------体验Windows和Ubuntu的结合体 最近看到有一款Wubuntu的文章&#xff0c;对于习惯使用windows操作系统&#xff0c;又不熟悉ubuntu系统的程序员小白来说&#xff0c;可以说是福音了。目前的Wubuntu兼容性可能还有一点问题&#xff0c;如果再迭代几次的…

Python库Gym:打开机器学习与强化学习的大门

Python库Gym&#xff1a;打开机器学习与强化学习的大门 强化学习作为人工智能领域的重要分支&#xff0c;已经在各种领域展现出了巨大的潜力。为了帮助开发者更好地理解和应用强化学习算法&#xff0c;Python库Gym应运而生。Gym提供了一个开放且易于使用的环境&#xff0c;供开…

阅读基础知识2

26 Linux中开放某个端口 在Linux中开放某个端口&#xff0c;通常需要配置防火墙规则来允许通过指定的端口号的网络流量。这里提供两种常用的防火墙管理工具的命令&#xff1a; 使用iptables&#xff08;内核空间防火墙&#xff09; 临时打开端口&#xff08;重启后失效&#xf…

win电脑安装绿色版MySQL8

一、下载压缩包 下载mysql server的zip文件&#xff0c;地址&#xff1a;Windows (x86, 64-bit), ZIP Archive 解压后&#xff1a; 二、创建配置文件&#xff08;可忽略&#xff09; 配置文件可存放位置及名称&#xff1a; C:\WINDOWS\my.ini C:\WINDOWS\my.cnf C:\my.ini…

招个Java工程师,却发现了一个宝藏平台

一直关注磊哥的朋友都知道&#xff0c;磊哥出来创业&#xff08;做 Java 就业指导&#xff09;也快一年了&#xff0c;从最初的纠结彷徨、不知所措&#xff0c;到现在逐渐找到自己的节奏&#xff0c;也算是半个媳妇熬成婆了。 磊哥现在每天做的事儿&#xff0c;就是通过文章和…

使用Navicat远程连接Linux中的MySQL

一、登录MySQL数据库 mysql -uroot -pXjm123456 二、使用mysql数据库 use mysql&#xff1b; 三、查询user表中包含host的字段 select user,host from user;### 该字段中&#xff0c;localhost表示只允许本机访问&#xff0c;可以将‘localhost’改为‘%’&#xff0c;‘%’表…

8.发布页面

发布页面 官网 https://vkuviewdoc.fsq.pub/components/form.html 复制官网中的内容 代码 write.vue <template><view class"u-wrap u-p-l-20 u-p-r-20"><u-form :model"addModel" ref"form1"><u-form-item label&quo…

深度强化学习06Actor-Critic

Critic裁判 裁判打分 提高自己的技术 提高打分水平

编译原理-实现识别标识符的词法分析器——沐雨先生

实验任务&#xff1a; 实现识别标识符的词法分析器 实验要求&#xff1a; 根据编译原理理论课教材中图2.3“标识符的转换图”&#xff0c;用C语言编写识别标识符的词法分析器&#xff0c;以文本文件为输入&#xff0c;控制台&#xff08;或文件&#xff09;输出识别出的每个…

uni app 打肉肉(打飞机)小游戏

都给老婆和孩子写了 合十 钓鱼了&#xff0c;给自己写个打飞机吧。没找飞机怪兽的图片。就用馒头和肉肉代替了。有问题不要私信我。自己改哈 <template><view class"page_main"><view class"contentone"><canvas class"canvas…

C语言每日一题(64)快乐数

题目链接 力扣网202 快乐数 题目描述 编写一个算法来判断一个数 n 是不是快乐数。 「快乐数」 定义为&#xff1a; 对于一个正整数&#xff0c;每一次将该数替换为它每个位置上的数字的平方和。然后重复这个过程直到这个数变为 1&#xff0c;也可能是 无限循环 但始终变不…

Flink源码解析(1)job启动,从JM到TM过程详解

网络传输模型 首先在看之前,回顾一下akka模型: Flink通讯模型—Akka与Actor模型-CSDN博客 注:ActorRef就是actor的引用,封装好了actor 下面是jm和tm在通讯上的概念图: RpcGateway 不理解网关的作用,可以先移步看这里:网关_百度百科 (baidu.com) 用于定义RPC协议,是…

【Python】【Pandas】详解Pandas模块常用函数

1. pandas简介 Pandas 是一个开源的第三方 Python 库,从 Numpy 和 Matplotlib 的基础上构建而来,享有数据分析“三剑客之一”的盛名(NumPy、Matplotlib、Pandas)。Pandas 已经成为 Python 数据分析的必备高级工具,它的目标是成为强大、灵活、可以支持任何编程语言的数据分…

torchvision pytorch预训练模型目标检测使用

参考&#xff1a; https://pytorch.org/vision/0.13/models.html https://blog.csdn.net/weixin_42357472/article/details/131747022 有分类、检测、分割相关预训练模型 1、目标检测 https://pytorch.org/vision/0.13/models.html#object-detection-instance-segmentation-…

四.流程控制(顺序,分支,循环,嵌套)

c刚刚转过来的记得写在public static void main&#xff08;String[] args&#xff09;的花括号里 一.顺序结构 二.分支结构 if &#xff0c;switch 1.if (条件判断&#xff09; 2.if else 3.if else if else if ... else(它是一个一个否定来一个个执行判断的 4.s…

以太坊开发学习-solidity(三)函数类型

目录 函数类型 函数类型 solidity官方文档里把函数归到数值类型 函数类型是一种表示函数的类型。可以将一个函数赋值给另一个函数类型的变量&#xff0c; 也可以将一个函数作为参数进行传递&#xff0c;还能在函数调用中返回函数类型变量。 函数类型有两类&#xff1a;- 内部&…

什么是虚拟dom

Virtual DOM&#xff08;虚拟DOM&#xff09; 就是由普通的 JS 对象来描述DOM对象&#xff0c;因为不是真实的DOM对象&#xff0c;所以叫 Virtual DOM。 虚拟DOM就是使用一个虚拟的 DOM 树来描述真实的 DOM 树结构和节点属性&#xff0c;通过比较新旧两颗虚拟 DOM 树的差异&…

如何删除全局的某个字符并替换js

let cons data[i].content.replace(/\/uploads\//g, 要替换的字符串/);console.log(data[i]); 该代码是将data数组中每个元素的content属性值中的"/uploads/"替换为"http://bas.xingyuncm.cn/uploads/"。 其中&#xff0c;replace()方法是字符串的方法&am…

day-24 腐烂的橘子

思路&#xff1a;利用bfs的思想 首先利用bfs遍历值为2的橘子&#xff08;遍历时1和2都可以走&#xff09;结束后如果存在某个橘子未被访问过且值为1则返回-1 再利用bfs遍历值为2的橘子 每遍历一次 时间加1 注意不要立即将map的值变为2&#xff0c;可以通过一个缓存数组临时存放…

CentOS7使用Docker部署.net Webapi

1 准备WebApi项目 对于已存在的WebApi项目&#xff0c;需要添加Docker支持&#xff1b; 编码时&#xff0c;先设置好项目需要的端口号&#xff1a;program.cs中&#xff0c;app.Run("http://*:8000");设置端口为&#xff1a;8000在VS中&#xff0c;选中项目&#xf…