python矩形填充颜色_在Python中找到所有用0填充的矩形

假设我们有一个二进制2D矩阵,现在我们必须找到所有用0填充的矩形的起点和终点。我们必须牢记,矩形是分开的,彼此之间不接触,但是它们可以接触阵列边界。仅包含单个元素的矩形也是可能的。

所以,如果输入像-1011101

1101111

1011001

1011001

1011011

1010000

1110001

1011101

那么输出将是[[0,1,0,1],[0,5,0,5],[1,2,1,2],[2,3,2,4],[3,1 ,5、1],[3、4、6、5],[5、3、6、5],[7、1、7、1],[7、5、7、5]]

为了解决这个问题,我们将遵循以下步骤-定义一个函数find_rect()。这将需要i,j,a,输出,索引

x:=行数

y:=列数

flag_col:= 0

flag_row:= 0

对于范围i至x的m在输出[索引]的末尾插入n

在输出[索引]的末尾插入n-1

在输出[索引]的末尾插入m在输出[索引]的末尾插入m-1

如果a [m,n]等于1,则

a [m,n]:= 5flag_col:= 1

打破

没做什么flag_row:= 1

打破

如果a [m,j]等于1,则

如果a [m,j]与5相同,则

对于j到y范围内的n

如果flag_row与1相同,则

除此以外,

如果flag_col与1相同,则

除此以外,

从主要方法中,执行以下操作-

n:=一个的大小

op:=一个新列表

idx:= -1

对于0到n范围内的i,执行如果a [i,j]等于0,则

将[i,j]插入op

idx:= idx + 1

find_rect(i,j,a,op,idx)

对于范围为0到a [0]大小的j,执行

显示操作

范例程式码

让我们看下面的实现以更好地理解-def find_rect(i,j,a,output,index):

x = len(a)

y = len(a[0])

flag_col = 0

flag_row = 0

for m in range(i,x):

if a[m][j] == 1:

flag_row = 1

break

if a[m][j] == 5:

pass

for n in range(j, y):

if a[m][n] == 1:

flag_col = 1

break

a[m][n] = 5

if flag_row == 1:

output[index].append( m-1)

else:

output[index].append(m)

if flag_col == 1:

output[index].append(n-1)

else:

output[index].append(n)

def get_coord(a):

n = len(a)

op = []

idx = -1

for i in range(0,n):

for j in range(0, len(a[0])):

if a[i][j] == 0:

op.append([i, j])

idx = idx + 1

find_rect(i, j, a, op, idx)

print (op)

tests = [[1, 0, 1, 1, 1, 0, 1],

[1, 1, 0, 1, 1, 1, 1],

[1, 1, 1, 0, 0, 1, 1],

[1, 0, 1, 1, 0, 0, 1],

[1, 0, 1, 1, 0, 1, 1],

[1, 0, 1, 0, 0, 0, 0],

[1, 1, 1, 0, 0, 0, 1],

[1, 0, 1, 1, 1, 0, 1]]

get_coord(tests)

输入值[[1, 0, 1, 1, 1, 0, 1],

[1, 1, 0, 1, 1, 1, 1],

[1, 1, 1, 0, 0, 1, 1],

[1, 0, 1, 1, 0, 0, 1],

[1, 0, 1, 1, 0, 1, 1],

[1, 0, 1, 0, 0, 0, 0],

[1, 1, 1, 0, 0, 0, 1],

[1, 0, 1, 1, 1, 0, 1]]

输出结果[[0, 1, 0, 1], [0, 5, 0, 5], [1, 2, 1, 2], [2, 3, 2, 4], [3, 1, 5, 1], [3, 4, 6, 5], [5, 3, 6, 5], [7, 1, 7, 1], [7, 5, 7, 5]]

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

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

相关文章

python concat_python中merge、concat用法

转载:https://blog.csdn.net/ly_ysys629/article/details/73849543 参考:https://blog.csdn.net/stevenkwong/article/details/52540605 数据规整化:合并、清理、过滤 pandas和python标准库提供了一整套高级、灵活的、高效的核心函数和算法将…

Vue使用axios无法读取data的解决办法

今天发现Vue中使用了axios后,then方法中无法读取到data中的数据了,总是提示 Cannot set property xxx of undefined 上网找了一圈后发现了一下解决方法。 解决办法1: methods:{tap:function(){var selfthis;axios.get(xxxxxx).then(function(…

设置博客园标题样式

1.向博客园申请js权限 我们需要进入博客园自定义博客模板的页面,向博客园管理团队申请页面运行js的权限。【博客园】->【设置】->【博客设置】,点击页面上的js权限申请,然后填写申请的理由,耐心等几分钟,再刷新一…

Spring 3.1 –从数据库加载XML配置的属性

Spring使通过其PropertyPlaceholderConfigurer和(Spring 3.1之前)PropertySourcesPlaceholderConfigurer(Spring 3.1)从属性文件中获取的值易于注入。 这些类实现了BeanFactoryPostProcessor接口,该接口使它们能够在初…

如何判断PHP 是线程安全还是非线程安全的

什么是线程安全与非线程安全? 线程安全就是在多线程环境下也不会出现数据不一致,而非线程安全就有可能出现数据不一致的情况。 线程安全由于要确保数据的一致性,所以对资源的读写进行了控制,换句话说增加了系统开销。所以在单线程…

关联查询mysql_《MySQL数据库》关联查询

原标题:《MySQL数据库》关联查询一、关联查询1、概念在查询数据时,所需要的数据不只在一张表中,可能在两张或多张表中。这个时候,需要同时操作这些表来查询数据,即关联查询。关联查询所涉及到的表与表之间都会存在有关…

python语言语块句的标记_《自然语言处理理论与实战》

编辑推荐 1.讲解自然语言处理的理论 2.案例丰富,实战性强 3.适合自然语言处理学习的入门者 内容提要 自然语言处理是什么?谁需要学习自然语言处理?自然语言处理在哪些地方应用?相关问题一直困扰着不少初学者。针对这一情况&#x…

NOIP2017年11月9日赛前模拟

最后一次NOIP模拟了 题目1:回文数字 Tom 最近在研究回文数字。  假设 s[i] 是长度为 i 的回文数个数(不含前导0),则对于给定的正整数 n 有: 以上等式中最后面的括号是布尔表达式,Tom 想知道S[n] mod 2333…

height百分比失效

heigh:100%失效 解决方案: 第一种 html, body { height: 100%; } 第二种 div { height: 100%; position: absolute; } 非定位元素的宽高百分比计算不会将 padding 计算在内,而定位元素会计算在内。 利用这个特性可以实现图片左右半区点击分别上一张图…

Java堆空间,本机堆和内存问题

最近,我在和一个朋友讨论为什么Java进程使用的内存比启动Java进程时设置的最大堆多。 代码创建的所有Java对象都是在Java堆空间内创建的,其大小由-Xmx选项定义。 但是一个Java进程由很多空间组成,而不仅仅是Java堆空间。 以下是组成Java进程…

mysql视图表怎么设置约束_MySQL一一sql的视图、索引、约束

一、视图本质上相当于一张**“虚拟表”**,可当作独立的一张表进行操作(增、删、改、查)** 作用:**** a)**可通过权限控制,只将“表中的少数列”暴露给数据库用户,而不让该用户直接操纵数据库中“实际表”** b)**…

Software Development Life Cycle

转载于:https://www.cnblogs.com/genezhao/p/6879848.html

python中 的用法_详解python中@的用法

python中的用法 是一个装饰器,针对函数,起调用传参的作用。 有修饰和被修饰的区别,function作为一个装饰器,用来修饰紧跟着的函数(可以是另一个装饰器,也可以是函数定义)。 代码1 结果1 Its fun…

ArrayAndString(数组和字符串)

1.实现一个算法,确定一个字符串的所有字符是否全都不同。假使不允许使用额外的数据结构,又该怎么处理? public class UniqueChars {public static void main(String[] args) {// TODO Auto-generated method stubString string "abcdef…

MyBatis教程– CRUD操作和映射关系–第2部分

为了说明这一点,我们正在考虑以下示例域模型: 会有用户,每个用户可能都有一个博客,每个博客可以包含零个或多个帖子。 这三个表的数据库结构如下: CREATE TABLE user (user_id int(10) unsigned NOT NULL auto_incr…

position 的属性值

理论上来说,全部 position 的取值有8个 包括:position:static | relative | absolute | fixed | sticky | initial | inherit | unset 其中最常用的是 static 、relative、absolute、fixed 和 sticky initial、inherit、unset 是css的关键…

[ JavaScript ] JavaScript 实现继承.

对于javascript中的继承,因为js中没有后端语言中的类式继承。所以js中的继承,一般都是原型继承(prototype)。 function P (name){this.name name;this.say function(){console.log(p);} }function S (name,id){this.id id;this.eat function(){conso…

mysql数据库应用的权限层级_MySQL数据库的用户权限管理

嗨!各位小伙伴今天翻了一下历史记录MySQL 数据库还有点内容今天开始我们就来补上吧~用户权限管理伙伴们要知道,在数据库方面有两个方向。一个是数据库管理员(Database Administrator)简称DBA,一个是数据库开发工程师(Database Developer)&…

linux i2c adapter 增加设备_Linux驱动之I2C驱动架构

一、Linux的I2C体系结构主要由三部分组成:(1) I2C核心提供I2C控制器和设备驱动的注册和注销方法,I2C通信方法,与适配器无关的代码以及探测设备等。(2) I2C控制器驱动(适配器)(3) I2C设备驱动二、重要的结构体i2c_adapter//i2c控制器(适配器)i…

Alpha-end

前言 失心疯病源10团队代码管理github个人感悟 肝不动了,肝不动了。明天如果见不到我,不要太想我。站立会议 队名:PMS530雨勤(组长) 今天完成了那些任务 熬夜肝代码代码签入github明天的计划 肝到凌晨还剩下哪些任务 团…