螺旋矩阵算法(leetcode第59题)

题目描述:

cpp 复制代码
给你一个正整数 n ,生成一个包含 1 到 n2 所有元素,且元素按顺时针顺序螺旋排列的 n x n 正方形矩阵 matrix 。

示例 1:

输入:n = 3
输出:[[1,2,3],[8,9,4],[7,6,5]]
示例 2:

输入:n = 1
输出:[[1]]
 

提示:

1 <= n <= 20

算法:

思路:

设定四个边界,每次输出完一行 或者一列,就移动边界,直到边界相碰

代码实现:
cpp 复制代码
/**
 * Return an array of arrays of size *returnSize.
 * The sizes of the arrays are returned as *returnColumnSizes array.
 * Note: Both returned array and *columnSizes array must be malloced, assume caller calls free().
 */
# include<stdio.h>
# include<stdlib.h>
int** generateMatrix(int n, int* returnSize, int** returnColumnSizes) {
    *returnSize=n;//行空间
    *returnColumnSizes=(int*)malloc(n*sizeof(int));//行空间
    for(int i=0;i<n;i++) (*returnColumnSizes)[i]=n;//列空间
    int **matrix=(int**)malloc(n*sizeof(int*));
    for(int i=0;i<n;i++){
        matrix[i]=(int*)malloc(sizeof(int)*n);
    }
    int num=1;
    //四个边界值
    int right=n-1,left=0,up=0,down=n-1;
    //条件:不超过边界 or num不超过n^2
    while(up<=down && left<=right){  //up<=down && left<=right 或 num<=n*n
        for(int i=left;i<=right;i++) matrix[up][i]=num++;
        up++;//上边界下移
        for(int i=up;i<=down;i++) matrix[i][right]=num++;
        right--;//右边界左移
        for(int i=right;i>=left;i--) matrix[down][i]=num++;
        down--;//下边界上移
        for(int i=down;i>=up;i--) matrix[i][left]=num++;
        left++;//左边界右移
    }
    return matrix;
}
相关推荐
MadPrinter几秒前
FindQC 实战 (一):基于 SerpApi 的电商高质量图片自动化筛选算法初探
运维·python·算法·自动化
小毅&Nora2 分钟前
【人工智能】【深度学习】 ③ DDPM核心算法介绍:从噪声到图像的魔法
人工智能·深度学习·算法
h***01543 分钟前
图解缓存淘汰算法 LRU、LFU | 最近最少使用、最不经常使用算法 | go语言实现
算法·缓存·golang
sheeta19983 分钟前
LeetCode 每日一题笔记 日期:2025.12.01 题目:2141.同时运行 N 台电脑的最长时间
笔记·leetcode·电脑
moonquakeTT4 分钟前
雷达信号处理中的CFAR检测关键要点
人工智能·算法·目标跟踪·fmcw毫米波
元亓亓亓5 分钟前
LeetCode热题100--34. 在排序数组中查找元素的第一个和最后一个位置--中等
数据结构·算法·leetcode
ComputerInBook9 分钟前
理解数学概念——素数(质数)(prime)
算法·数论·质数·素数
旧梦吟12 分钟前
脚本网页 推理游戏
算法·css3·html5·web app
语落心生14 分钟前
海量数据集的AI自动化预测打标 -- 放电时序特征
算法
CodeByV17 分钟前
【双指针】复写零
数据结构·算法