Python 旋轉(zhuǎn)打印各種矩形的方法
打印旋轉(zhuǎn)矩陣應(yīng)該是很經(jīng)典的算法問(wèn)題了。
題目描述如下:
給定一個(gè)m * n要素的矩陣。按照螺旋順序,返回該矩陣的所有要素。
思路:1,先定義矩陣的左上和右下的坐標(biāo),然后通過(guò)兩個(gè)坐標(biāo)來(lái)打印這一圈矩陣;
2,將左上的坐標(biāo)下右下移動(dòng),右下的坐標(biāo)向左上移動(dòng),來(lái)縮小打印圈,進(jìn)行下一圈矩陣的打??;
3,一直縮小打印直到結(jié)束。
代碼:
def print_circle(matrix,up_hang,up_lie,down_hang,down_lie): result=[] if up_lie==down_hang and down_hang==down_lie: # 若只有一個(gè)元素 result.append(matrix[up_hang][up_lie]) elif up_lie==down_hang or up_lie==down_lie: #若只有一行或一列元素 if up_lie==down_hang: while up_lie <= down_lie: result.append(matrix[up_hang][up_lie]) up_lie+=1 elif up_lie==down_lie: while up_hang <=down_hang: result.append(matrix[up_hang][up_lie]) up_hang+=1 # return result #注意對(duì)齊方式,其決定了作用的區(qū)間范圍,很關(guān)鍵 return result i=up_hang j=up_lie while j<down_lie: result.append(matrix[i][j]) j+=1 while i<down_hang: result.append(matrix[i][j]) i+=1 while j>up_lie: result.append(matrix[i][j]) j-=1 while i>up_hang: result.append(matrix[i][j]) i-=1 return result #matrix=[[1,2,3],[4,5,6],[7,8,9],[10,11,12],[13,14,15],[16,17,18]] #matrix=[[1,2,3,4,5],[6,7,8,9,10],[11,12,13,14,15],[16,17,18,19,20],[21,22,23,24,25]] matrix=[[1,2,3,4],[5,6,7,8],[9,10,11,12],[13,14,15,16]] #matrix=[[1,2,3],[4,5,6],[7,8,9]] #matrix=[[1,2],[3,4]] re_mat=[] up_hang=0 up_lie=0 down_hang=3 down_lie=3 if down_hang>down_lie: flag=down_lie else: flag=down_hang while flag!=0: #flag決定了一個(gè)矩陣需要打印多少圈 temp=print_circle(matrix,up_hang,up_lie,down_hang,down_lie) re_mat.extend(temp) up_hang+=1 up_lie+=1 down_hang-=1 down_lie-=1 flag=flag/2 print(re_mat)
總結(jié):python對(duì)于代碼的對(duì)齊方式要求的比較嚴(yán)格,對(duì)齊方式直接決定了函數(shù)或者判斷條件的作用域,要重視啊。
以上這篇Python 旋轉(zhuǎn)打印各種矩形的方法就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
django models里數(shù)據(jù)表插入數(shù)據(jù)id自增操作
這篇文章主要介紹了django models里數(shù)據(jù)表插入數(shù)據(jù)id自增操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-07-07pandas 實(shí)現(xiàn)字典轉(zhuǎn)換成DataFrame的方法
今天小編就為大家分享一篇pandas 實(shí)現(xiàn)字典轉(zhuǎn)換成DataFrame的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-07-07Python多進(jìn)程加鎖的實(shí)現(xiàn)
很多時(shí)候,我們需要在多個(gè)進(jìn)程中同時(shí)寫一個(gè)文件,如果不加鎖機(jī)制,就會(huì)導(dǎo)致寫文件錯(cuò)亂,本文主要介紹了Python多進(jìn)程加鎖的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),感興趣的可以了解一下2023-07-07Python+Opencv實(shí)現(xiàn)物體尺寸測(cè)量的方法詳解
這篇文章主要為大家詳細(xì)介紹了Python+Opencv如何實(shí)現(xiàn)物體尺寸測(cè)量的功能,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2022-09-09Python 實(shí)現(xiàn)數(shù)據(jù)結(jié)構(gòu)-循環(huán)隊(duì)列的操作方法
這篇文章主要介紹了Python 實(shí)現(xiàn)數(shù)據(jù)結(jié)構(gòu)-循環(huán)隊(duì)列的操作方法,需要的朋友可以參考下2019-07-07基于django micro搭建網(wǎng)站實(shí)現(xiàn)加水印功能
這篇文章主要介紹了基于django micro搭建網(wǎng)站實(shí)現(xiàn)加水印功能,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-05-05python 簡(jiǎn)易計(jì)算器程序,代碼就幾行
運(yùn)行環(huán)境:python 3.1,代碼比較短,大家可以參考下。2009-08-08