• 《剑指offer》第二十九题:顺时针打印矩阵


    // 面试题29:顺时针打印矩阵
    // 题目:输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字。
    
    #include <cstdio>
    
    void PrintMatrixInCircle(int** numbers, int columns, int rows, int start);
    void printNumber(int number);
    
    void PrintMatrixClockwisely(int** numbers, int columns, int rows)
    {
        if (numbers == nullptr || columns <= 0 || rows <= 0)
            return;
    
        int start = 0; //每圈的开始起点
        while (columns > start * 2 && rows > start * 2) //当前圈存在
        {
            PrintMatrixInCircle(numbers, columns, rows, start);
    
            ++start;
        }
    }
    
    void PrintMatrixInCircle(int** numbers, int columns, int rows, int start)
    {
        int endX = columns - 1 - start;
        int endY = rows - 1 - start;
    
        //从左到右打印圈第一行
        for (int i = start; i <= endX; ++i)
        {
            int number = numbers[start][i];
            printNumber(number);
        }
    
        //从上到下打印圈右列
        if (start < endY) //右列存在条件, 两列
        {
            for (int i = start + 1; i <= endY; ++i)
            {
                int number = numbers[i][endX];
                printNumber(number);
            }
        }
    
        //从右到左打印圈第二行
        if (start < endX && start < endY) //两行两列
        {
            for (int i = endX - 1; i >= start; --i)
            {
                int number = numbers[endY][i];
                printNumber(number);
            }
        }
    
    
        //从下到上打印圈左列
        if (start < endY - 1 && start < endX) //三行两列
        {
            for (int i = endY - 1; i > start; --i)
            {
                int number = numbers[i][start];
                printNumber(number);
            }
        }
    }
    
    void printNumber(int number)
    {
        printf("%d	", number);
    
    }
    // ====================测试代码====================
    void Test(int columns, int rows)
    {
        printf("Test Begin: %d columns, %d rows.
    ", columns, rows);
    
        if (columns < 1 || rows < 1)
            return;
    
        int** numbers = new int* [rows];
        for (int i = 0; i < rows; ++i)
        {
            numbers[i] = new int[columns];
            for (int j = 0; j < columns; ++j)
            {
                numbers[i][j] = i * columns + j + 1;
            }
        }
    
        PrintMatrixClockwisely(numbers, columns, rows);
        printf("
    ");
    
        for (int i = 0; i < rows; ++i)
            delete[](int*)numbers[i];
    
        delete[] numbers;
    }
    
    int main(int argc, char* argv[])
    {
        /*
        1
        */
        Test(1, 1);
    
        /*
        1    2
        3    4
        */
        Test(2, 2);
    
        /*
        1    2    3    4
        5    6    7    8
        9    10   11   12
        13   14   15   16
        */
        Test(4, 4);
    
        /*
        1    2    3    4    5
        6    7    8    9    10
        11   12   13   14   15
        16   17   18   19   20
        21   22   23   24   25
        */
        Test(5, 5);
    
        /*
        1
        2
        3
        4
        5
        */
        Test(1, 5);
    
        /*
        1    2
        3    4
        5    6
        7    8
        9    10
        */
        Test(2, 5);
    
        /*
        1    2    3
        4    5    6
        7    8    9
        10   11   12
        13   14   15
        */
        Test(3, 5);
    
        /*
        1    2    3    4
        5    6    7    8
        9    10   11   12
        13   14   15   16
        17   18   19   20
        */
        Test(4, 5);
    
        /*
        1    2    3    4    5
        */
        Test(5, 1);
    
        /*
        1    2    3    4    5
        6    7    8    9    10
        */
        Test(5, 2);
    
        /*
        1    2    3    4    5
        6    7    8    9    10
        11   12   13   14    15
        */
        Test(5, 3);
    
        /*
        1    2    3    4    5
        6    7    8    9    10
        11   12   13   14   15
        16   17   18   19   20
        */
        Test(5, 4);
    
        return 0;
    }
    测试代码

    分析:画图举例很方便,可以直观的算出各种条件。注意条件不要写错了。


    牛客网给出了容器vector,注意:

    int rows = (int)matrix.size();
    int columns = (int)matrix[0].size();
    class Solution {
    public:
        vector<int> printMatrix(vector<vector<int>> matrix) {
            
            int start = 0;
            int rows = (int)matrix.size();
            int columns = (int)matrix[0].size();
            vector<int> printNumber;
            
            if (rows == 0 || columns == 0)
                return printNumber;
            
            while (columns > start * 2 && rows > start * 2)
            {
                int endX = columns - 1 - start;
                int endY = rows - 1 - start;
    
                for (int i = start; i <= endX; ++i)
                {
                    int number = matrix[start][i];
                    printNumber.push_back(number);
                }
                if (start < endY)
                {
                    for (int i = start + 1; i <= endY; ++i)
                    {
                        int number = matrix[i][endX];
                        printNumber.push_back(number);
                    }
                }
                if (start < endX && start < endY)
                {
                    for (int i = endX - 1; i >= start; --i)
                    {
                        int number = matrix[endY][i];
                        printNumber.push_back(number);
                    }
                }
                if (start < endX && start < endY - 1)
                {
                    for (int i = endY - 1; i > start; --i)
                    {
                        int number = matrix[i][start];
                        printNumber.push_back(number);
                    }
                }
                ++start;
            }
            return printNumber;
        }
    };
    牛客网提交代码
  • 相关阅读:
    mtk lk阶段的lcm流程
    MTK touchscreen 流程
    MTK DDR调试
    增加,删除GMS包
    最大最小背光亮度修改
    HDMI 8193 配置
    mtk6737t摄像头配置文件的编译
    camera调试命令
    Linux 终端显示 Git 当前所在分支
    ubuntu系统,关于源(source)的配置
  • 原文地址:https://www.cnblogs.com/ZSY-blog/p/12591436.html
Copyright © 2020-2023  润新知