剑指Offer18 顺时针打印矩阵

Posted Juntaran

tags:

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

/*************************************************************************
    > File Name: 18_PrintMatrixClock.c
    > Author: Juntaran
    > Mail: [email protected]
    > Created Time: 2016年08月30日 星期二 17时32分28秒
 ************************************************************************/

#include <stdio.h>
#include <stdlib.h>

#define COL 4
#define ROW 1

void PrintMatrixCircle(int nums[][COL], int col, int row, int start)
{
    // 从左到右打一行
    for (int i = start; i < col-start; ++i)
    {
        int number = nums[start][i];
        printf("%d ", number);
    }
    
    // 从上到下打一列
    if (start < row-start-1)
    {
        for (int i = start + 1; i < row-start; ++i)
        {
            int number = nums[i][start];
            printf("%d ", number);
        }
    }
    
    // 从右到左打一行
    if (start < col-start-1 && start < row-start-1)
    {
        for (int i = col-start-2; i >= start; --i)
        {
            int number = nums[row-start-1][i];
            printf("%d ", number);
        }
    }
    
    // 从下到上打一列
    if (start < col-start-1 && start < row-start-2)
    {
        for (int i = row-start-2; i >= start + 1; --i)
        {
            int number = nums[i][start];
            printf("%d ", number);
        }
    }
}

void PrintMatrixClock(int nums[][COL], int col, int row)
{
    if (nums==NULL || col<=0 || row<=0)
        return;
    int start = 0;
    
    while (col>start*2 && row>start*2)
    {
        PrintMatrixCircle(nums, col, row, start);
        ++start;
    }
}

int main()
{
    int nums[ROW][COL] = {{1,2,3,4},{5,6,7,8},{9,10,11,12},{13,14,15,16}};
    
    PrintMatrixClock(nums, COL, ROW);
    
    return 0;
}

 

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

剑指offer顺时针打印矩阵python

剑指 Offer 29. 顺时针打印矩阵 的 详细题解

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

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

剑指offer:顺时针打印矩阵

剑指offer 19.顺时针打印矩阵