问题

螺旋矩阵

给定一个包含 m x n 个元素的矩阵(m 行, n 列),请按照顺时针螺旋顺序,返回矩阵中的所有元素。

示例 1:

输入:

[

[ 1, 2, 3 ],

[ 4, 5, 6 ],

[ 7, 8, 9 ]

]

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

示例 2:

输入:

[

[1, 2, 3, 4],

[5, 6, 7, 8],

[9,10,11,12]

]

输出: [1,2,3,4,8,12,11,10,9,5,6,7]

分析

限定好前进方向以及边界,一个一个遍历下去即可,最近开始用Go,感觉很是不错,特意选了Go练习,AC code如下

···

func spiralOrder(matrix [][]int) []int {

var ret []int

ret = make([]int, 0)

n := len(matrix)

if n == 0 {

return ret

}

m := len(matrix[0])

//获取到了矩阵大小,
counter := 0 //记录处理个数
limu, limd, liml, limr := -1, n, -1, m
tmpx, tmpy := 0, 0
direction := 0 // 0 right 1 down 2 left7 3 up
for {
if counter == n*m {
return ret
}
ret = append(ret, matrix[tmpx][tmpy])
counter++
getNextIndex(&limu, &limd, &liml, &limr, &direction, &tmpx, &tmpy)
}

}

//获取下一个坐标,同时有可能更新方向、边界等

func getNextIndex(limu *int, limd *int, liml *int, limr *int, direction *int, x *int, y int) {

//fmt.Println(
limu, *limd, *liml, *limr, *direction, *x, *y)

switch *direction {

case 0:

//to right

if *y+1 < *limr {

//正常更新

*y += 1

return

} else {

//到了右边界,需要更新方向以及边界,已经通过个数限定,所以改变方向后肯定可行

*limu += 1

*direction = 1

*x += 1

}

case 1:

//to down

if *x+1 < *limd {

//正常更新

*x += 1

return

} else {

//到了下边界,需要更新方向以及边界,

*limr -= 1

*direction = 2

*y -= 1

}

case 2:

//to right

if *y-1 > *liml {

//正常更新

*y -= 1

return

} else {

//到了左边界,需要更新方向以及边界,

*limd -= 1

*direction = 3

*x -= 1

}

case 3:

//to up

if *x-1 > *limu {

//正常更新

*x -= 1

return

} else {

//到了左边界,需要更新方向以及边界,已经通过个数限定,所以改变放下后肯定可行

*liml += 1

*direction = 0

*y += 1

}

}

}

···

其他

1.初次提交后由于空输入错了一次,应该更多的考虑特殊情况。

2.使用go的另一个好处就是可以很方便的进行测试,比如main.go中编写了解题函数,只需要一个公开的壳函数就能在mai_test.go中测试

···

func TspiralOrder(matrix [][]int) []int {

return spiralOrder(matrix)

}

···

而在测试中通过编写测试数据测试结果,可以方便的添加新的测试数据,同时能够避免改动导致原本能通过的数据failed。

···

func TestTspiralOrder(t *testing.T) {

var testData [][][]int

var tmpdata [][]int

var testReslut [][]int

var tmpanswer []int

tmpdata = [][]int{
{1, 2, 3},
{4, 5, 6},
{7, 8, 9}}
testData = append(testData, tmpdata)
tmpanswer = []int{1, 2, 3, 6, 9, 8, 7, 4, 5}
testReslut = append(testReslut, tmpanswer) tmpdata = [][]int{
{1, 2, 3, 4},
{5, 6, 7, 8},
{9, 10, 11, 12}}
testData = append(testData, tmpdata)
tmpanswer = []int{1, 2, 3, 4, 8, 12, 11, 10, 9, 5, 6, 7}
testReslut = append(testReslut, tmpanswer) tmpdata = make([][]int, 0)
testData = append(testData, tmpdata)
tmpanswer = make([]int, 0)
testReslut = append(testReslut, tmpanswer) for i := 0; i != len(testData); i++ {
tmp := TspiralOrder(testData[i])
fmt.Println(tmp)
if IsTwoArraySame(tmp, testReslut[i]) == true {
fmt.Println("Pass")
} else {
fmt.Println("Failed")
}
}

}

···

LeetCode之螺旋矩阵的更多相关文章

  1. LeetCode:螺旋矩阵||【59】

    LeetCode:螺旋矩阵||[59] 题目描述 给定一个正整数 n,生成一个包含 1 到 n2 所有元素,且元素按顺时针顺序螺旋排列的正方形矩阵. 示例: 输入: 3 输出: [ [ 1, 2, 3 ...

  2. LeetCode:螺旋矩阵【54】

    LeetCode:螺旋矩阵[54] 题目描述 给定一个包含 m x n 个元素的矩阵(m 行, n 列),请按照顺时针螺旋顺序,返回矩阵中的所有元素. 示例 1: 输入: [ [ 1, 2, 3 ], ...

  3. LeetCode 59. 螺旋矩阵 II(Spiral Matrix II)

    题目描述 给定一个正整数 n,生成一个包含 1 到 n2 所有元素,且元素按顺时针顺序螺旋排列的正方形矩阵. 示例: 输入: 3 输出: [ [ 1, 2, 3 ], [ 8, 9, 4 ], [ 7 ...

  4. Java实现 LeetCode 59 螺旋矩阵 II

    59. 螺旋矩阵 II 给定一个正整数 n,生成一个包含 1 到 n2 所有元素,且元素按顺时针顺序螺旋排列的正方形矩阵. 示例: 输入: 3 输出: [ [ 1, 2, 3 ], [ 8, 9, 4 ...

  5. Java实现 LeetCode 54 螺旋矩阵

    54. 螺旋矩阵 给定一个包含 m x n 个元素的矩阵(m 行, n 列),请按照顺时针螺旋顺序,返回矩阵中的所有元素. 示例 1: 输入: [ [ 1, 2, 3 ], [ 4, 5, 6 ], ...

  6. leetcode 54. 螺旋矩阵 及 59. 螺旋矩阵 II

    54. 螺旋矩阵 问题描述 给定一个包含 m x n 个元素的矩阵(m 行, n 列),请按照顺时针螺旋顺序,返回矩阵中的所有元素. 示例 1: 输入: [ [ 1, 2, 3 ], [ 4, 5, ...

  7. [Leetcode]59.螺旋矩阵Ⅱ

    给定一个正整数 n,生成一个包含 1 到 n2 所有元素,且元素按顺时针顺序螺旋排列的正方形矩阵. 示例: 输入: 3 输出: [ [ 1, 2, 3 ], [ 8, 9, 4 ], [ 7, 6, ...

  8. LeetCode 54. 螺旋矩阵(Spiral Matrix) 剑指offer-顺时针打印矩阵

    题目描述 给定一个包含 m x n 个元素的矩阵(m 行, n 列),请按照顺时针螺旋顺序,返回矩阵中的所有元素. 示例 1: 输入: [ [ 1, 2, 3 ], [ 4, 5, 6 ], [ 7, ...

  9. LeetCode 59. Spiral Matrix II (螺旋矩阵之二)

    Given an integer n, generate a square matrix filled with elements from 1 to n2 in spiral order. For ...

随机推荐

  1. 使用JS判断客户端、浏览器、操作系统类型

    一.JS判断客户端类型 JS判断客户端是否是iOS或者Android手机移动端 通过判断浏览器的userAgent,用正则来判断手机是否是ios和Android客户端. 核心代码如下: 方法一: &l ...

  2. github版本库使用详细教程(命令行及图形界面版)

    Git是一个分布式的版本控制系统,作为开源代码库以及版本控制系统,Github目前拥有140多万开发者用户.随着越来越多的应用程序转移到了云上,Github已经成为了管理软件开发以及发现已有代码的首选 ...

  3. Linux新硬盘、分区、格式化、自动挂载

    1.给硬盘分区 fdisk /dev/sdaCommand (m for help): nCommand actione extendedp primary partition (1-4)输入:ePa ...

  4. Java EE学习笔记(八)

    动态SQL 1.动态SQL中的元素 1).作用:无需手动拼装SQL,MyBatis已提供的对SQL语句动态组装的功能,使得数据库开发效率大大提高! 2).动态SQL是MyBatis的强大特性之一,My ...

  5. spark-2.2.0-bin-hadoop2.6和spark-1.6.1-bin-hadoop2.6发行包自带案例全面详解(java、python、r和scala)之Basic包下的JavaPageRank.java(图文详解)

    不多说,直接上干货! spark-1.6.1-bin-hadoop2.6里Basic包下的JavaPageRank.java /* * Licensed to the Apache Software ...

  6. IQueryable和IEnumerable的区别

  7. Author: Jan Odvarko, www.janodvarko.cz

    /*  * Author: Jan Odvarko, www.janodvarko.cz */ FBL.ns(function() { with (FBL) { function HelloWorld ...

  8. jquery显示隐藏效果

    通过 jQuery,您可以使用 hide() 和 show() 方法来隐藏和显示 HTML 元素toggle() 方法来切换 hide() 和 show() 方法. 1.hide()隐藏元素 $(se ...

  9. ios获取数据之encodeURI 和 decodeURI

    在APP开发过程中,免不了要进行ios的数据处理,在ios传递数据的过程中,会出现JSON数据获取不到的情况,这时候就轮到encodeURI 和 decodeURI出马了. 1.encodeURI,d ...

  10. 【js类库Raphaël】使用raphael.js根据点坐标绘制平滑曲线

     一.可供参考的文档资料. raphaeljs官网:http://raphaeljs.com/ w3c关于path的介绍:http://www.w3.org/TR/2003/REC-SVG11-200 ...