golang顺时针打印矩阵

栏目: Go · 发布时间: 6年前

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

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

金字塔原理

金字塔原理

[美] 巴巴拉·明托 / 王德忠、张珣 / 民主与建设出版社 / 2002-12 / 39.80元

《金字塔原理》是一本讲解写作逻辑与思维逻辑的读物,全书分为四个部分。 第一篇主要对金字塔原理的概念进行了解释,介绍了如何利用这一原理构建基本的金字塔结构。目的是使读者理解和运用简单文书的写作技巧。 第二篇介绍了如何深入细致地把握思维的环节,以保证使用的语句能够真实地反映希望表达的思想要点。书中列举了许多实例,突出了强迫自己进行“冷静思维”对明确表达思想的重要性。 第三篇主要针对的......一起来看看 《金字塔原理》 这本书的介绍吧!

HTML 压缩/解压工具
HTML 压缩/解压工具

在线压缩/解压 HTML 代码

XML 在线格式化
XML 在线格式化

在线 XML 格式化压缩工具

html转js在线工具
html转js在线工具

html转js在线工具