顺时针打印矩阵——20

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了顺时针打印矩阵——20相关的知识,希望对你有一定的参考价值。

    输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字。例如,输入如下矩阵:

        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。


    其实顺时针的打印,无非就是先打印出矩阵最外面的第一行,然后是最后一列,然后是最后一行,最后是第一列,每一次打印时控制的条件也就是矩阵的行和列的边界,那么打印完一圈之后只需要改变打印的范围也就是首尾行和首尾列就可以再打印里面的矩阵;


程序设计如下:

#include <iostream>
#include <assert.h>
using namespace std;
    
void ClockwisePrintArr(int arr[][5], size_t row, size_t col)
{
    assert(arr && row && col);//条件判断

    int (*tmp)[5] = arr;
    
    //第一次开始的行为0,列也为0,打印终止的行为形参行数,列也为形参列数
    int start_row = 0;
    int start_col = 0;
    int end_row = row;
    int end_col = col;
    //判断条件当开始边界小于终止边界的时候
    while((start_row < end_row) && (start_col < end_col))
    {   
            //打印矩阵第一行
        for(int i = start_col; i < end_col; ++i)
        {
            cout<<tmp[start_row][i]<<" ";
        }
            //打印矩阵最后一列
        for(int i = start_row+1; i < end_row; ++i)
        {
            cout<<tmp[i][end_col-1]<<" ";
        }
                //打印矩阵最后一行
        for(int i = end_col-2; i >= start_col; --i)
        {
            cout<<tmp[end_row-1][i]<<" ";
        }
                 //打印矩阵第一列
        for(int i = end_row-2; i > start_row; --i)
        {
            cout<<tmp[i][start_col]<<" ";
        }
                //依次将打印的边界缩小一圈
        ++start_row;
        ++start_col;
        --end_row;
        --end_col;
    }
    cout<<endl;
}

int main()
{
    int arr[5][5] = {{0,  1,  2,  3,  4},
              {5,  6,  7,  8,  9},
              {10, 11, 12, 13, 14},
              {15, 16, 17, 18, 19},
              {20, 21, 22, 23, 24}};

    ClockwisePrintArr(arr, sizeof(arr)/sizeof(arr[0]), sizeof(arr[0])/sizeof(arr[0][0]));

    return 0;
}


运行程序:

技术分享



《完》

本文出自 “敲完代码好睡觉zzz” 博客,请务必保留此出处http://2627lounuo.blog.51cto.com/10696599/1774031

以上是关于顺时针打印矩阵——20的主要内容,如果未能解决你的问题,请参考以下文章

面试题20顺时针打印数组

《剑指offer》面试题20 顺时针打印矩阵 Java版

剑指offer面试题 29. 顺时针打印矩阵

剑指offer面试题 29. 顺时针打印矩阵

顺时针打印矩阵

剑指offer--29顺时针打印矩阵