順時針列印矩陣

来源:http://www.cnblogs.com/sankexin/archive/2016/06/26/5618360.html
-Advertisement-
Play Games

題目:輸入一個矩陣,按照從外向里以順時針的順序依次列印出每一個數字。 例如輸入以下矩陣: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 則依次列印出數字 1、2、3、4、8、12、16、15、14、13、9、5、6、7、11、10 ...


題目:輸入一個矩陣,按照從外向里以順時針的順序依次列印出每一個數字。

          例如輸入以下矩陣:

           1    2    3    4

           5    6    7    8

           9   10   11  12

          13  14   15  16

          則依次列印出數字 1、2、3、4、8、12、16、15、14、13、9、5、6、7、11、10

  1 #include<stdio.h>
  2 #include<iostream>
  3 #include<tchar.h>
  4 
  5 void PrintMatrixInCircle(int** numbers, int columns, int rows, int start);
  6 void printNumber(int number);
  7 
  8 
  9 //方法1 
 10 void PrintMatrixClockwisely(int** numbers, int columns, int rows)
 11 {
 12     if(numbers == NULL || columns <= 0 || rows <= 0)
 13         return;
 14     
 15     int start = 0 ;
 16     
 17     while(columns > start * 2 && rows > start * 2)
 18     {
 19         PrintMatrixInCircle(numbers, columns, rows, start);
 20         
 21         ++start;
 22     }
 23 }
 24 
 25 //列印一圈 
 26 void PrintMatrixInCircle(int** numbers, int columns, int rows, int start)
 27 {
 28     // rows 行
 29     // columns 列 
 30     int endX = columns - 1 - start;   //x方向水平向右 
 31     int endY = rows - 1 - start;     //y方向垂直向下 
 32     
 33     //從左到右列印一行 
 34     for(int i = start; i <= endX; ++i)
 35     {
 36         int number = numbers[start][i];
 37         printNumber(number);
 38     }
 39     
 40     //從上到下列印一行
 41     if(start < endY) 
 42     {
 43         for(int i = start + 1; i <= endY; ++i)
 44         {
 45             int number = numbers[i][endX];
 46             printNumber(number);
 47         }
 48     }
 49     
 50     //從右到左列印一行
 51     if(start < endX && start < endY) 
 52     {
 53         for(int i = endX - 1; i >= start; --i)
 54         {
 55             int number = numbers[endY][i];
 56             printNumber(number);
 57         }
 58     }
 59     
 60     //從下到上列印一行
 61     if(start < endX && start < endY - 1) 
 62     {
 63         for(int i = endY - 1; i >= start + 1; --i)
 64         {
 65             int number = numbers[i][start];
 66             printNumber(number);
 67         }
 68     }
 69 }
 70 
 71 void printNumber(int number)
 72 {
 73     printf("%d\t", number);
 74 }
 75 
 76 
 77 //方法2     
 78 void PrintMatrixCircle(int** numbers, int startX, int startY, int endX, int endY);
 79 void PrintMatrixClockwisely1(int** numbers, int columns, int rows)
 80 {
 81     if(numbers == NULL || columns <= 0 || rows <= 0)
 82         return;
 83 
 84     //rows 行
 85     //columns 列
 86     int startX = 0; 
 87     int startY = 0;
 88     int endX = rows - 1;      //x 方向垂直向下 
 89     int endY = columns - 1;  //y 方向水平向右 和方法1的x,y方法不同 不過並不重要 
 90     
 91     while(true)
 92     {
 93         if(startX > endX && startY > endY)
 94             break;
 95         if(startX == endX && startY > endY)
 96             break;
 97         if(startX > endX && startY == endY)
 98             break;
 99 
100         PrintMatrixCircle(numbers, startX, startY, endX, endY);
101         ++startX;
102         ++startY;
103         --endX;
104         --endY;
105     }
106 }
107 
108 void PrintMatrixCircle(int** numbers, int startX, int startY, int endX, int endY)
109 {
110     //只有一行的情況,直接列印。 
111     if(startX == endX && startY != endY)
112     {
113         for(int j = startY; j <= endY; ++j)
114         {
115             int number = numbers[startX][j];
116             printNumber(number);
117         }
118     }
119     
120     
121     //ps 當最後只有一個數字時,一行一列都列印,為了避免重覆
122     //在只有一行的情況下,加了一個 startY != endY. 
123      
124     //只有一列的情況,直接列印。 
125     if(startY == endY)
126     {
127         for(int i = startX ; i <= endX; ++i)
128         {
129             int number = numbers[i][startY];
130             printNumber(number);
131         }
132     }
133     
134     //列印一圈 
135     for(int p = startY; p < endY; ++p)
136     {
137         int number = numbers[startX][p];
138         printNumber(number);
139     }
140 
141     for(int q = startX; q < endX; ++q)
142     {
143         int number = numbers[q][endY];
144         printNumber(number);
145     }
146 
147     for(int m = endY; m > startY ; --m)
148     {
149         int number = numbers[endX][m];
150         printNumber(number);
151     }
152     for(int n = endX; n > startX; --n)
153     {
154         int number = numbers[n][startY];
155         printNumber(number);
156     }
157 }
158 
159 
160 
161 int main(int argc, _TCHAR* argv[]) 
162 {
163     
164     /*
165     1    2    3    4    5
166     6    7    8    9    10
167     11   12   13   14   15
168     16   17   18   19   20
169     21   22   23   24   25
170     */
171     
172     int columns = 5;
173     int rows = 5;
174     
175     if(columns < 1 || rows < 1)
176         exit(1);
177 
178     int** numbers = new int*[rows];
179     for(int i = 0; i < rows; ++i)
180     {
181         numbers[i] = new int[columns];
182         for(int j = 0; j < columns; ++j)
183         {
184             numbers[i][j] = i * columns + j + 1;
185         }
186     }
187     printf("Solution1 Begin: %d columns, %d rows.\n", columns, rows);
188     PrintMatrixClockwisely(numbers, columns, rows);
189     printf("\n");
190     printf("\n");
191     
192     printf("Solution2 Begin: %d columns, %d rows.\n", columns, rows);
193     
194     PrintMatrixClockwisely1(numbers, columns, rows);
195     
196     
197     for(int i = 0; i < rows; ++i)
198         delete[] (int*)numbers[i];
199 
200     delete[] numbers;
201     printf("\n");
202     
203     return 0;
204 }


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 為什麼要有內部類?都有哪些內部類?它們都適合用在什麼場景?內部類最後都會轉換為獨立的類,它們是如何轉換的?為什麼內部類可以訪問外部類的私有變數和方法?為什麼方法內部類可以訪問方法參數?但參數又為什麼必須要聲明為final? ... ...
  • 目錄 前言 1 不使用開發工具 1.1 自動重啟工具 1.2 瀏覽器自動刷新工具 2 阻塞event loop 3 頻繁調用回調函數 4 聖誕樹結構的回調(回調的地獄) 5 創建一個大而完整的應用程式 6 缺少日誌 7 沒有測試 8 不使用靜態分析工具 9 沒有監視與性能分析 10 使用consol ...
  • Matplotlib作為Python中著名的數據可視化工具,其官網也提供了在PyQt4中使用的源碼,這裡舉一個應用實例,以備不時之需。 1) 利用Qt Designer創建GUI界面 Demo的GUI界面,如圖1所示,其中利用QFrame作為放置Matplotlib界面的容器。然後調用pyuic4. ...
  • 1.header PHP文件插入header("Content-type: text/html; charset=utf-8");相當於頁面裡面的<meta http-equiv="Content-Type" content="text/html; charset=utf-8">;目的:防止頁面出現 ...
  • 1. 一般來說,導入objective c的頭文件時用#import,包含c/c++頭文件時用#include。 2. #import 確定一個文件只能被導入一次,這使你在遞歸包含中不會出現問題。<標記> 所以,#import比起#include的好處就是不會引起交叉編譯。 #import && # ...
  • 一、利用google提供的的zxing生成不包含logo的二維碼 運行main方法後在: 二、利用google的zxing生成包含logo的二維碼 使用簡介: 在QEcodeUtil.java類中: 運行main方法後生成的二維碼: 三、使用Jquery.qrcode生成二維碼 下載項目使用: 代碼 ...
  • php-resque是一個輕量級的消息隊列,讓我們一起來瞭解一下它的設計和使用 ...
  • HELLO WORLD! 今天第一次開立博客,專門記載學習編程語言中的點點滴滴。今日學習內容: 搭建vs code+ python3.5 "ide" 學習廖雪峰python教程-使用list和tuple 因為之前有pascal基礎,所以學起來不是很難理解,但是貴在堅持,自我激勵。昨天《墊底辣妹》給打 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...