国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > Python > 正文

python實現回旋矩陣方式(旋轉矩陣)

2024-09-09 19:02:57
字體:
來源:轉載
供稿:網友

我們知道Python中是沒有數組 這種數據結構的,所以要想實現回旋矩陣,需要先導入一個numpy包, 它是一個由多維數組對象和用于處理數組的例程集合組成的python擴充程序庫,可以用來做數組算數和邏輯運算

思路:

首先創建一個n*m全為零的矩陣,然后按照旋轉規律依次替換里面的值

最外層的循環代表替換一圈數據,這一圈數據在數組中的形狀是一個矩形,我們分析可以知道,最后一輪循環有兩種情況:

1、替換一圈(矩形)數據

2、替換一個數據

如果是第一種情況,我們讓循環正常運行就可以了,但是如果是第二種,就需要加一個if語句進行判斷。因為最后一輪大循環只需要替換一個數據,那么我們只需要讓它走完第一個小循環最后一個元素必然被替換,所以只需要在第一個小循環后判斷一下替換的最后一個元素是否等于理論上最后一個元素的值即可

import numpy as npdef rotary_matrix(n,m): array=np.zeros((n,m)) #起始點 x=y=0 ret=array[x][y]=1 #設置一個變量i用來在循環中判斷是否需要旋轉矩陣 i = 0 while ret < n*m:  #從上邊一行開始由左到右添加元素  while y<m-1-i:   y+=1   ret+=1   array[x][y]=ret     #若ret等于最后一個元素的值,則表示所有元素添加完畢,這時候可以退出循環  if ret == n * m:   break     # 從右邊一列開始由上到下添加元素  while x<n-1-i:   x+=1   ret+=1   array[x][y] = ret  # 從下邊一行開始由右到左添加元素  while y>0+i:   y-=1   ret+=1   array[x][y]=ret  # 從左邊一列開始由下到上添加元素  while x>0+1+i:   x-=1   ret+=1   array[x][y] = ret     i+=1 print(array)

以上這篇python實現回旋矩陣方式(旋轉矩陣)就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持武林網之家。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 清涧县| 贵港市| 寻乌县| 黔江区| 曲靖市| 永仁县| 台南县| 库尔勒市| 阳泉市| 获嘉县| 德江县| 宁城县| 余庆县| 扶绥县| 隆林| 绥中县| 南乐县| 湖州市| 吉林省| 房产| 梁河县| 丰县| 泊头市| 获嘉县| 手游| 顺昌县| 西充县| 杭锦后旗| 崇文区| 乌拉特后旗| 抚松县| 玉田县| 逊克县| 泸定县| 剑川县| 光泽县| 桂东县| 延庆县| 封丘县| 泸西县| 陵水|