19.旋转输出矩阵

1.题目描述

复制代码
输入:matrix = [[1,2,3],[4,5,6],[7,8,9]]
输出:[1,2,3,6,9,8,7,4,5]

2.解题思路

设置上下左右四个边界,每次遍历一行或者一列,对边界进行缩减,对于C语言需要先创建一个数组,当ans数组元素大于矩阵元素个数就退出循环

3.代码

cpp 复制代码
int* spiralOrder(int** matrix, int matrixSize, int* matrixColSize, int* returnSize) {
    //matrixSize是二维矩阵的行数
    //*matrixColSize指向每一行有多少列,但标准矩阵的话里面每个元素都是一样的,可以用matixColSize[0]表示列数
     //  处理边界情况:空矩阵
    if (matrixSize == 0 || matrixColSize[0] == 0) {
        *returnSize = 0;
        return NULL;
    }
    int row = matrixSize;
    int col = matrixColSize[0];
    *returnSize = row * col;//returnSize是一个指针,指向一个int类型,保存返回的元素个数,也就是总元素个数
    int *ans = (int*)malloc(*returnSize * sizeof(int));
    int cnt = 0;
    int left = 0;
    int up = 0;
    int right = col-1;
    int down = row-1;
    while(cnt<row*col)
    {
        //从左边界遍历到右边界,上边界向下加一
        for(int i = left; i<=right;i++){//从左边界向右边界遍历
            ans[cnt] = matrix[up][i];//up是上边界0,向下缩
            cnt++;
        }
        up++;//遍历完第一行上边界往下缩一行
        if(up > down) break;//如1*5的矩阵,第一次遍历完up = 1 > down=0 直接退出
    //从上边界遍历到下边界,右边界向左减一
    for(int i = up; i<=down;i++ ){
        ans[cnt] = matrix[i][right];
        cnt++;
    }
    right--;
    if(right < left) break;

    //开始从右边界遍历到左边界,下边界减一
    for(int i = right; i>=left;i--){
        ans[cnt]= matrix[down][i];
        cnt++;
    }
    down--;
    if(down < up) break;
    //开始从下边界遍历到上边界,左边界加一
    for(int i = down;i>=up;i--){
        ans[cnt] = matrix[i][left];
        cnt++;
    }
    left++;
    if(left > right) break;
    }
    return ans;

}
相关推荐
CoovallyAIHub17 小时前
181小时视频丢给GPT-5,准确率只有15%——南大联合NVIDIA等五校发布多模态终身理解数据集
深度学习·算法·计算机视觉
CoovallyAIHub18 小时前
CVPR 2026 | GS-CLIP:3D几何先验+双流视觉融合,零样本工业缺陷检测新SOTA,四大3D工业数据集全面领先!
深度学习·算法·计算机视觉
xlp666hub18 小时前
Leetcode 第三题:用C++解决最长连续序列
c++·leetcode
会员源码网19 小时前
构造函数抛出异常:C++对象部分初始化的陷阱与应对策略
c++
有意义20 小时前
深度拆解分割等和子集:一维DP数组与倒序遍历的本质
前端·算法·面试
xlp666hub21 小时前
Leetcode第二题:用 C++ 解决字母异位词分组
c++·leetcode
用户7268761033721 小时前
解放双手的健身助手:基于 Rokid AR 眼镜的运动计时应用
算法
Wect1 天前
LeetCode 17. 电话号码的字母组合:回溯算法入门实战
前端·算法·typescript
不想写代码的星星1 天前
static 关键字:从 C 到 C++,一篇文章彻底搞懂它的“七十二变”
c++