【leetcode刷题笔记】Spiral Matrix

Given a matrix of m x n elements (m rows, n columns), return all elements of the matrix in spiral order.

For example,
Given the following matrix:

[
 [ 1, 2, 3 ],
 [ 4, 5, 6 ],
 [ 7, 8, 9 ]
]

You should return [1,2,3,6,9,8,7,4,5].


题解:还是找规律的题:设有四个变量Xs,Xe,Ys,Ye,如下图所示,它们分别代表当前还未处理的子矩阵的边界,初始为图一所示;运算过程的某一时刻如图二所示

那么螺旋输出就是不停的重复以下四个步骤,直到矩阵所有的元素被输出:

1.输出matrix[Xs->Xe][Ys],Ys++  即1,2,3

2.输出matrix[Xe][Ys->Ye],Xe--  即6,9

3.输出matrix[Xe->Xs][Ye],Ye--  即8,7

4.输出matrix[Ye->Ys][Xs],Xs++  即4

代码如下:

 1 #include<iostream>
 2 #include<vector>
 3 using namespace std;
 4 class Solution {
 5 public:
 6     vector<int> spiralOrder(vector<vector<int> > &matrix) {
 7         vector<int> ans;
 8 
 9         if(matrix.size() == 0)
10             return ans;
11 
12         int Xs = 0,Xe = matrix[0].size()-1,Ys = 0,Ye = matrix.size()-1;
13         int total = (Xe+1) * (Ye+1);
14 
15         for(int i = 0;i <= total;){
16             for(int k = Xs;k <= Xe;k++)
17             {
18                 ans.push_back(matrix[Ys][k]);
19                 i++;
20             }
21             if(i >= total)
22                 break;
23             else
24                 Ys++;
25 
26             for(int k = Ys;k <= Ye;k++)
27             {
28                 ans.push_back(matrix[k][Xe]);
29                 i++;
30             }
31             if(i >= total)
32                 break;
33             else
34                 Xe--;
35 
36             for(int k = Xe;k >= Xs;k--)
37             {
38                 ans.push_back(matrix[Ye][k]);
39                 i++;
40             }
41             if(i >= total)
42                 break;
43             else
44                 Ye--;
45 
46             for(int k = Ye;k >= Ys;k--)
47             {
48                 ans.push_back(matrix[k][Xs]);
49                 i++;
50             }
51             if(i >= total)
52                 break;
53             else
54                 Xs++;
55         }
56         return ans;
57     }
58 };
59 int main(){
60     Solution s;
61     vector<vector<int> > m;
62     vector<int>temp(1,1);
63     m.push_back(temp);
64 
65     vector<int> ans(s.spiralOrder(m));
66     cout <<ans.size()<<endl;
67 }

这里学习到了怎么接受函数返回回来的向量,直接定义新的向量初始化为函数返回值就可以了,如代码65行所示。

 

转载于:https://www.cnblogs.com/sunshineatnoon/p/3698702.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值