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.pswp.cn/news/370657.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/370657.shtml
英文地址,請注明出處:http://en.pswp.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明天的計劃 肝到凌晨還剩下哪些任務 團…