剑指offer 顺时针打印矩阵

题目描述

输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字,例如,如果输入如下矩阵: 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.

思路:一定要记住循环继续的条件是columns > start * 2,rows > start * 2;

一圈的打印分为四步:

第一步:无条件打印第一行,从左往右;

第二步:终止行号大于起始行号,打印最后一列,从上往下;

第三步:至少有两行两列才能进行打印,要求起始行号小于终止行号,起始列号小于终止列号,从左往右打印。

第四步:至少需要三行两列才能进行打印,终止行号比起始行号至少大2,终止列号大于起始列号。

分为两个函数,一个函数实现打印一圈的功能,另一个函数实现主循环。

 1 class Solution {
 2 public:
 3     void printfCircle(vector<vector<int> > matrix,vector<int>& result,int start,int rows,int columns){
 4         int endRows = rows - start - 1;
 5         int endColumns = columns - start - 1;
 6         //打印第一行
 7         for(int i = start;i <= endColumns;++i){
 8             result.push_back(matrix[start][i]);
 9         }
10         //打印最后一列
11         if(start < endRows){
12             for(int i = start + 1;i <= endRows;++i){
13                 result.push_back(matrix[i][endColumns]);
14             }
15         }
16         //打印最后一行
17         if(start < endRows && start < endColumns){
18             for(int i = endColumns - 1;i >= start;--i){
19                 result.push_back(matrix[endRows][i]);
20             }
21         }
22         //打印第一列
23         if(start < endRows - 1 && start < endColumns){
24             for(int i = endRows - 1;i >= start + 1;--i){
25                 result.push_back(matrix[i][start]);
26             }
27         }
28     }
29     vector<int> printMatrix(vector<vector<int> > matrix) {
30         vector<int> result;
31         if(matrix.empty()){
32             return {};
33         }
34         if(matrix[0].empty()){
35             return {};
36         }
37         int start = 0;
38         int rows = matrix.size(),columns = matrix[0].size();
39         while(rows > 2*start && columns > 2*start){
40             printfCircle(matrix,result,start,rows,columns);
41             ++start;
42         }
43         return result;
44     }
45 };
时间: 2024-11-05 14:44:02

剑指offer 顺时针打印矩阵的相关文章

剑指offer顺时针打印矩阵python

题目描述 输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字,例如,如果输入如下4 X 4矩阵: 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. 思路 分别给行和列设置两个数字作为边界值,每一次循环之后,缩小边界. 代码 # -*- coding:utf-8 -*- class Solution: # matrix类型为二维列表,需要返回列表 def print

剑指offer--26.顺时针打印矩阵

1,2,3,45,6,7,88,10,11,1213,14,15,16 每次输出第一行,然后删除第一行,逆时针旋转剩下的矩阵. ------------------------------------------------------------------------------------------------------------------------ 时间限制:1秒 空间限制:32768K 热度指数:430225 本题知识点: 数组 题目描述 输入一个矩阵,按照从外向里以顺时针的

剑指Offer18 顺时针打印矩阵

/************************************************************************* > File Name: 18_PrintMatrixClock.c > Author: Juntaran > Mail: [email protected] > Created Time: 2016年08月30日 星期二 17时32分28秒 **********************************************

剑指offer (20) 打印螺旋矩阵

题目描述: 输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字 class Solution { public: vector<int> spiralOrder(vector<vector<int> > &matrix) { vector<int> result; int nRows = matrix.size(); if (nRows == 0) return result; int nCols = matrix.at(0).size()

剑指OFFER之打印1到最大的N位数(九度OJ1515)

题目描述: 给定一个数字N,打印从1到最大的N位数. 输入: 每个输入文件仅包含一组测试样例.对于每个测试案例,输入一个数字N(1<=N<=5). 输出: 对应每个测试案例,依次打印从1到最大的N位数. 样例输入: 1 样例输出: 1 2 3 4 5 6 7 8 9 解题思路: 直接通过n快速指定比最大的那个数大1的数,10,100,1000,10000,100000.... 输出,就行了... 代码: #include <stdio.h> int main(void){ int

剑指offer (12) 打印1到最大的n位数

题目描述: 给定一个数字N,打印从1到最大的N位数 此题需要注意以下几点: 1. 涉及到大数问题,因为并没有限定 n的取值范围,所以需要采取 字符数组模拟大数运算 2. 打印数字时 需要忽略前置0 3. 我们始终 以n位数为整体,n位所有十进制数其实是 n位从0到9的全排列,可以采用递归解决 我们从 数组下标0开始 (对应于数字最高位),每一位都有0到9取值,然后设置下一位,递归的结束条件是 设置位到了数组的最末端 1 void PrintNum(char* num) 2 { 3 char* c

剑指offer-顺时针打印矩阵-二维数组

输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字,例如,如果输入如下矩阵: 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. import java.util.ArrayList; public class Solution { public static ArrayList<Integer> printMatrix(int

【模板小程序】循环方阵构造(仿《剑指offer》循环矩阵打印)

1 /* 2 本程序说明: 3 4 输入:方阵大小n,输出:n*n的旋转方阵 5 6 举例: 7 当n=2时,输出: 8 1 2 9 4 3 10 当n=4时,输出: 11 1 2 3 4 12 12 13 14 5 13 11 16 15 6 14 10 9 8 7 15 16 */ 17 #include <iostream> 18 #include <vector> 19 20 using namespace std; 21 22 void PrintMatrixInCirc

[遇见时光]剑指offer-顺时针打印矩阵java

题目描述: 输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字,例如,如果输入如下矩阵: 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. 输入: 输入可能包含多个测试样例,对于每个测试案例, 输入的第一行包括两个整数m和n(1<=m,n<=1000):表示矩阵的维数为m行n列. 接下来的m行,每行包括n个整数,表示矩阵的元素,其中每个元素a的取值范围为(1&l