【算法題】螺旋矩陣III (求解n階蛇形矩陣)

一、問題的提出

n階蛇形矩陣的特點是按照圖1所示的方式排列元素。n階蛇形矩陣是指矩陣的大小為n×n,其中n為正整數。

題目背景

一個?n??n?列的螺旋矩陣可由如圖1所示的方法生成,觀察圖片,找出填數規律。填數規則為從?1?開始填到?n×n

圖1??n??n?列的螺旋矩陣(蛇形矩陣)

?現在給出矩陣大小?n?以及?i??j,請你求出該矩陣中第?i?行第?j?列的數是多少。

題目描述

輸入格式

從標準輸入讀入數據。 共一行,包含三個整數?n1n1,000)、i1in)、j1jn),每兩個整數之間用一個空格隔開,分別表示矩陣大小、待求的數所在的行號和列號。

輸出格式

輸出到標準輸出。 一個整數,表示相應矩陣中第?i?行第?j?列的數。

輸入輸出樣例

輸入 #1復制

8 2 8

輸出 #1復制

43

說明/提示

子任務

  • 對于?30%?的測試數據,n10
  • 對于?60%?的測試數據,n100
  • 對于?100%?的測試數據,n1,000
  • 特別地,對于?20%?的測試數據,i=j=1

提示

根據本題的填數規則,一個?8×8?的螺旋矩陣應該長這樣(如圖2所示):

圖2 88列的螺旋矩陣(蛇形矩陣)

?二、解題的思路

由圖3可知,這是個旋轉45o的Z形矩陣,當然折返長度是不相等的。仔細看圖1發現:當向右上方填數時,如行號為0則向右(行號不變,列號加1),如是列號到n時則向下(列號減1,行號加1),然后向左下方填數,此時,如列號為0則向下,如是行號到n時則向右(行號減1,列號加1),然后向右一方填數,如此重復直到最后行、最后列填完為止。

圖3 蛇形矩陣分析圖

三、矩陣生成算法

nn列,第一行為0行,第一列為0列。從(0,0)1開始,方向設為從左下往右上。

當從左下往右上時,如行號已為0則列號加1方向向反(從右上往左下),否則行號減1,列號加1,如列號達n則列號為n-1,行號加1方向向反(從右上往左下)

當從右上往左下時,如列號已為0則行號加1方向向反(從左下往右上),否則行號加1,列號減1,如行號達n則列號加1,行號為n-1方向向反(從左下往右上)

當行號和列號都為n-1時結束。

程序代碼如下:

def prt(hm):???????????????? # 打印二維列表for i in range(N):for j in range(N):print("%3d" % hm[i][j], end='')print()def Helix_MatrixII(n):cnt = 1i = j = 0k = 1while True:matrix[i][j] = cntif i == n-1 and j == n-1:breakif k == 1:?????????? # 從左下往右上 if i == 0 :j += 1if j >= n:j = n-1i = i+1 if i < n -1 else n-1k = -1elif j == n-1:i += 1k = -1else:i -= 1j += 1else:?????????       # 從右上往左下if j == 0 :i += 1if i >= n:i = n-1j = j+1 if j < n -1 else n-1k = 1elif i == n-1:j += 1k = 1else:i += 1j -= 1cnt += 1N = 7
matrix = []???????????? # 初始化二維矩陣matrix(二維列表)
for i in range(N):matrix.append([])for j in range(N):matrix[i].append(0)
Helix_MatrixII(N)
prt(matrix)

執行結果:

?四、題目求解算法

題目要求輸入矩陣規模n和坐標(i, j)三個參數,求出矩陣(i, j)處的元素值。所以先按n求出矩陣,現按坐標輸出元素值。

程序代碼如下:

def Helix_MatrixII(n):cnt = 1i = j = 0k = 1while True:matrix[i][j] = cntif i == n-1 and j == n-1:breakif k == 1:        # 從左下往右上if i == 0 :j += 1if j >= n:j = n-1i = i+1 if i < n -1 else n-1k = -1elif j == n-1:i += 1k = -1else:i -= 1j += 1else:             # 從右上往左下if j == 0 :i += 1if i >= n:i = n-1j = j+1 if j < n -1 else n-1k = 1elif i == n-1:j += 1k = 1else:i += 1j -= 1cnt += 1N, x, y = map(int, input().split())
matrix = []????????????   # 初始化二維矩陣matrix(二維列表)
for i in range(N):matrix.append([])for j in range(N):matrix[i].append(0)
Helix_MatrixII(N)
print(matrix[x-1][y-1])

執行結果:

?

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/40053.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/40053.shtml
英文地址,請注明出處:http://en.pswp.cn/news/40053.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

【配置環境】Linux下安裝MySQL

目錄 一&#xff0c;環境 二&#xff0c;安裝步驟 1.使用包管理器安裝MySQL 2.配置MySQL的安全選項 3.設置root用戶使用密碼進行身份驗證&#xff08;可選&#xff09; 三&#xff0c;拓展知識 1.如何修改MySQL的密碼策略&#xff1f; 2.實現連接MySQL數據庫的測試代碼…

TiDB基礎介紹、應用場景及架構

1. 什么是newsql NewSQL 是對各種新的可擴展/高性能數據庫的簡稱&#xff0c;這類數據庫不僅具有NoSQL對海量數據的存儲管理能力&#xff0c;還保持了傳統數據庫支持ACID和SQL等特性。 NewSQL是指這樣一類新式的關系型數據庫管理系統&#xff0c;針對OLTP&#xff08;讀-寫&…

經驗分享:企業數據倉庫建設方案總結!

導讀 在企業的數字化轉型浪潮中&#xff0c;數據被譽為“新時代的石油”&#xff0c;而數據倉庫作為數據管理與分析的核心基礎設施&#xff0c;在企業的信息化建設中扮演著重要的角色。本文將深入探討企業數據倉庫建設過程中所遇到的問題以及解決經驗&#xff0c;為正在籌備或…

進程/線程上下文切換會用掉你多少CPU?

進程是操作系統的偉大發明之一&#xff0c;對應用程序屏蔽了CPU調度、內存管理等硬件細節&#xff0c;而抽象出一個進程的概念&#xff0c;讓應用程序專心于實現自己的業務邏輯既可&#xff0c;而且在有限的CPU上可以“同時”進行許多個任務。但是它為用戶帶來方便的同時&#…

嵌入式Linux Qt5 (C++)開發欄目概述

本欄目開始介紹Linux系統下的Qt C程序開發&#xff0c;資源是以嵌入式為切入點&#xff08;現在Linux系統下的Qt C程序開發好像就是應用于嵌入式&#xff09;&#xff0c;那就跟著一起學習Linux系統下的Qt C程序開發知識&#xff0c;再擴展一下嵌入式的知識吧。我這里默認已經熟…

php初解

php是什么&#xff1f; PHP&#xff0c;全稱 Hypertext Preprocessor &#xff0c;中文翻譯“超文本預處理器”。 PHP是一種被廣泛應用的開源通用腳本語言&#xff0c;尤其適用于 Web 開發。 擁有快速&#xff0c;靈活&#xff0c;實用的特點&#xff0c;PHP能做任何事&#xf…

ORACLE中UNION、UNION ALL、MINUS、INTERSECT學習

1、UNION和UNION ALL的使用與區別 如果我們需要將兩個select語句的結果作為一個整體顯示出來&#xff0c;我們就需要用到union或者union all關鍵字。union的作用是將多個結果合并在一起顯示出來。 union和union all的區別是union會自動壓縮多個結果集合中的重復結果&#xff…

高速下載VisualGLM模型文件的解決方案

大家好,我是愛編程的喵喵。雙985碩士畢業,現擔任全棧工程師一職,熱衷于將數據思維應用到工作與生活中。從事機器學習以及相關的前后端開發工作。曾在阿里云、科大訊飛、CCF等比賽獲得多次Top名次。現為CSDN博客專家、人工智能領域優質創作者。喜歡通過博客創作的方式對所學的…

GO語言自底向上優化

Go Ballast(通過嘗試降低 GC 頻率以提高整體性能&#xff0c;針對所有 Go應用都適用) 首先我們明白GO語言GC觸發條件是由比例來觸發的。例如&#xff0c;當前存活內存10GB&#xff0c;觸發比例是100%&#xff0c;因此下次觸發GC的時候是當內存達到20GB的時候觸發GC。這種機制在…

碎片筆記|圖數據與圖神經網絡基礎介紹

前言&#xff1a;前段時間了解了一下圖神經網絡&#xff0c;本篇博客記錄一下相關知識&#xff0c;以備不時之需。 強烈推薦這篇博客&#xff08;作者來自 Google Research&#xff09;&#xff0c;個人認為是圖神經網絡基礎入門的不二選擇&#xff01; 目錄 一、圖數據1.1 定義…

Windows上使用FFmpeg實現本地視頻推送模擬海康協議rtsp視頻流

場景 Nginx搭建RTMP服務器FFmpeg實現海康威視攝像頭預覽&#xff1a; Nginx搭建RTMP服務器FFmpeg實現海康威視攝像頭預覽_nginx rtmp 海康攝像頭_霸道流氓氣質的博客-CSDN博客 上面記錄的是使用FFmpeg拉取海康協議攝像頭的rtsp流并推流到流媒體服務器。 如果在其它業務場景…

TCP/IP協議組

TCP/IP通信協議是目前最完整、使用最廣泛的通信協議。它的魅力在于可使不同硬件結構、不同操作系統的計算機相互通信。TCP/IP協議既可用于廣域網&#xff0c;也可用于局域網&#xff0c;它是Internet/Intranet的基石。TCP/IP通信協議事實上是一組協議。 TCP/IP協議可分為5層也可…

使用 Redis 實現共享 Session 的高效解決方案

系列文章目錄 文章目錄 系列文章目錄前言一、為什么需要共享 Session?二、使用 Redis 實現共享 Session1.安裝和配置 Redis2.實現 Session 存取操作3.使用 Session 數據三、測試共享 Session四、注意事項總結前言 在分布式系統中,實現共享 Session 是一個重要的問題。本文將…

GT Code - 圖譯算法編輯器(集成QT、C++、C、Linux、Git、java、web、go、高并發、服務器、分布式、網絡編程、云計算、大數據項目)

目錄 項目概述 發文意義 項目介紹 功能分析 設計概要 功能展示 項目文檔 項目概述 “GT Code 圖譯算法編輯器”是一款跨平臺、輕量級的代碼編輯器&#xff0c;主要面向軟件開發人員&#xff0c;它實現了編輯、編譯、繪制代碼流程圖、生成調試演示動畫等功能&#xff0c;以…

go版本glog/klog 參數使用方法心得

問題 glog很好用&#xff0c;但是官方文檔卻很爛&#xff0c;對于很多參數并沒有做詳細說明&#xff0c;于是通過看源碼測試&#xff0c;總結出以下使用方法 可選參數 flag.BoolVar(&logging.toStderr, "logtostderr", false, "log to standard error in…

空間分析專屬 Python 學習資料

空間數據分析能夠幫助我們更好地理解地理空間中的模式和關系&#xff0c;從而為決策提供支持。例如&#xff0c;城市規劃者可以使用空間數據分析來確定城市發展的最佳方向&#xff0c;環境科學家可以使用空間數據分析來評估污染的影響&#xff0c;而商業分析師可以使用空間數據…

react go實現用戶歷史登錄列表頁面

refer: http://ip-api.com/ 1.首先需要創建一個保存用戶歷史的登錄的表&#xff0c;然后連接go 2.在用戶登錄的時候&#xff0c;獲取用戶的IP IP位置&#xff0c;在后端直接處理數據即可&#xff08;不需要在前端傳遞數據&#xff09; &#xff08;1&#xff09;增加路由&am…

使用Java服務器實現UDP消息的發送和接收(多線程)

目錄 簡介&#xff1a;1. 導入必要的庫2. 創建服務器端代碼3. 創建客戶端代碼4. 實現多線程處理5. 測試運行示例代碼&#xff1a;函數說明服務器端代碼說明&#xff1a;客戶端代碼說明&#xff1a; 總結&#xff1a; 簡介&#xff1a; 在本篇博客中&#xff0c;我們將介紹如何…

genism word2vec方法

文章目錄 概述使用示例模型的保存與使用訓練參數詳解&#xff08;[原鏈接](https://blog.csdn.net/weixin_44852067/article/details/130221655)&#xff09;語料庫訓練 概述 word2vec是按句子來處理的Sentences(句子們) 使用示例 from gensim.models import Word2Vec #sent…

《起風了》C++源代碼

使用方法 Visual Studio、Dev-C、Visual Studio Code等C/C創建一個 .cpp 文件&#xff0c;直接粘貼賦值即可。 #include <iostream> #include <Windows.h> #pragma comment(lib,"winmm.lib") using namespace std; enum Scale {Rest 0, C8 108, B7 …