内容简介:输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字,例如,如果输入如下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.
题目描述
输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字,例如,如果输入如下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.
package main
import "fmt"
func main() {
//s := [][]int{{1, 2, 3, 4}, {5, 6, 7, 8}, {9, 10, 11, 12}, {13, 14, 15, 16}}
//s := [][]int{{1}, {2}, {3}, {4}}
//s := [][]int{{1, 2, 3, 4}, {5, 6, 7, 8}}
s := [][]int{{1, 2}, {5, 6}, {9, 10}, {13, 14}}
printMatrix(s)
}
func printMatrix(s [][]int) {
if s == nil {
fmt.Println("切片为空,无法打印")
}
bex, bey := 0, 0
hang := len(s) - 1
lie := len(s[0]) - 1
if hang == 0 {
for _, v := range s[0] {
fmt.Println(v)
}
return
}
if lie == 0 {
for _, v := range s {
fmt.Println(v[0])
}
return
}
for bex <= hang && bey <= lie {
ax, ay := bex, bey
for ay < lie {
fmt.Println(s[ax][ay])
ay++
}
for ax < hang {
fmt.Println(s[ax][ay])
ax++
}
for ay > bey {
fmt.Println(s[ax][ay])
ay--
}
for ax > bex {
fmt.Println(s[ax][ay])
ax--
}
bex++
bey++
hang--
lie--
}
}
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:- 剑指Offer对答如流系列 - 顺时针打印矩阵
- 机器学习 | SVD矩阵分解算法,对矩阵做拆分,然后呢?
- golang 算法-矩阵
- 彻底理解矩阵乘法
- [开源项目]矩阵数据的意义
- iphone – :CGAffineTransformInvert:奇异矩阵
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
Java技术手册(第6版)
Benjamin J Evans、David Flanagan / 安道 / 人民邮电出版社 / 2015-12-1 / 79.00
《Java技术手册 第6版》为《Java 技术手册》的升级版,涵盖全新的Java 7 和Java 8。第1部分介绍Java 编程语言和Java 平台,主要内容有Java 环境、Java 基本句法、Java 面向对象编程、Java 类型系统、Java的面向对象设计、Java 实现内存管理和并发编程的方式。第2部分通过大量示例来阐述如何在Java 环境中完成实际的编程任务,主要内容有编程和文档约定,使......一起来看看 《Java技术手册(第6版)》 这本书的介绍吧!