leetcode 题解 59.螺旋矩阵-ii(Typescript)

/*

 * @lc app=leetcode.cn id=59 lang=typescript

 *

 * [59] 螺旋矩阵 II

 */下面提供两种解法

//详细解法讲解见代码随想录(左闭右开)

点此

// @lc code=start

function generateMatrix(n: number): number[][] {

  let loopnum = 0,

    startx = 0,

    starty = 0,

    count = 1,

    i = 0,

    j = 0,

    offset = 1;

  let res: number[][] = new Array(n).fill(1).map((i) => new Array(n));

  while (loopnum++ < Math.floor(n / 2)) {

    //行从左到右

    for (j = starty; j < n - offset; j++) {

      res[startx][j] = count++;

    }

    //列从上到下

    for (i = startx; i < n - offset; i++) {

      res[i][j] = count++;

    }

    //行从右到左

    for (; j > starty; j--) {

      res[i][j] = count++;

    }

    //列从下到上

    for (; i > startx; i--) {

      res[i][j] = count++;

    }

    startx++;

    starty++;

    offset++;

  }

  //赋值中心元素

  if (n % 2 === 1) {

    res[startx][starty] = count;

  }

  return res;

}

// @lc code=end

 

讲解见力扣或我的54题题解(左闭右闭)

//点此

// @lc code=start

function generateMatrix(n: number): number[][] {

  let num = 1,

    top = 0,

    left = 0,

    right = n - 1,

    bottom = n - 1,

    targrt = n * n,

    i = 0,

    j = 0;

  let res: number[][] = new Array(n).fill(1).map((i) => new Array(n));

  while (num <= targrt) {

    for (i = left; i <= right; i++) {

      res[top][i] = num++;

    }

    //向下塌陷一排

    top++;

    for (j = top; j <= bottom; j++) {

      res[j][right] = num++;

    }

    //向左移动一列

    right--;

    for (i = right; i >= left; i--) {

      res[bottom][i] = num++;

    }

    //向上移动一排

    bottom--;

    for (j = bottom; j >= top; j--) {

      res[j][left] = num++;

    }

    //向右移动一列

    left++;

  }

  return res;

}

// @lc code=end

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值