当前位置: 首页 > wzjs >正文

体育论坛网站建设市场推广外包团队

体育论坛网站建设,市场推广外包团队,娄底本地做寄生虫网站,深圳手机网站前言 仅做学习使用,侵删 后面计划做LeetCode 100热题 什么是ARTS? 算法(Algorithm): 每周至少一道LeetCode算法题,加强编程训练和算法学习 阅读(Review): 阅读并点评至少一篇英文技术文章,提高英文水平 技巧 (Ti…

前言

仅做学习使用,侵删

后面计划做LeetCode 100热题

什么是ARTS?

算法(Algorithm): 每周至少一道LeetCode算法题,加强编程训练和算法学习

阅读(Review): 阅读并点评至少一篇英文技术文章,提高英文水平

技巧 (Tip):学习至少一个技术技巧,总结、归纳日常工作中遇到的知识点

分享(Share):分析一篇有关点和思考的技术文章,建立影响力,输出价值观

算法(Algorithm)

力扣第59题

59. 螺旋矩阵 II - 力扣(LeetCode)

题目描述

给你一个正整数 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

 

分析题目实际上是螺旋向内逐渐填充对应的数字即

  1. 从左向右填充第一行
  2. 从上到下填充最后一列
  3. 从右到左填充最后一行
  4. 从下到上填充最左一列

此题的问题关键点在于对每一条边的边界控制,需要统一采用一样的方式,统一的开闭区间左开右闭或者左闭右开。

代码随想录说:

 

下面的代码具体解释了每一步的目的,代码统一了处理原则。

解题方法

方法一:常规解法

class Solution {public int[][] generateMatrix(int n) {int[][] nums = new int[n][n];int startX = 0, startY = 0;  // 每一圈的起始点int offset = 1;int count = 1;  // 矩阵中需要填写的数字int loop = 1; // 记录当前的圈数int i, j; // j 代表列, i 代表行;while (loop <= n / 2) {// 顶部// 左闭右开,所以判断循环结束时, j 不能等于 n - offsetfor (j = startY; j < n - offset; j++) {nums[startX][j] = count++;}// 右列// 左闭右开,所以判断循环结束时, i 不能等于 n - offsetfor (i = startX; i < n - offset; i++) {nums[i][j] = count++;}// 底部// 左闭右开,所以判断循环结束时, j != startYfor (; j > startY; j--) {nums[i][j] = count++;}// 左列// 左闭右开,所以判断循环结束时, i != startXfor (; i > startX; i--) {nums[i][j] = count++;}startX++;startY++;offset++;loop++;}if (n % 2 == 1) { // n 为奇数时,单独处理矩阵中心的值nums[startX][startY] = count;}return nums;}
}
时间复杂度:

O(n2),其中 n 是给定的正整数。矩阵的大小是 n×n,需要填入矩阵中的每个元素。

即:模拟遍历二维矩阵的时间

空间复杂度:

O(1)。除了返回的矩阵以外,空间复杂度是常数。

以下是LeetCode官方题解

方法二:按层模拟

思想:

可以将矩阵看成若干层,首先填入矩阵最外层的元素,其次填入矩阵次外层的元素,直到填入矩阵最内层的元素。

定义矩阵的第 k 层是到最近边界距离为 k 的所有顶点。例如,下图矩阵最外层元素都是第 1 层,次外层元素都是第 2 层,最内层元素都是第 3 层。

[[1, 1, 1, 1, 1, 1],[1, 2, 2, 2, 2, 1],[1, 2, 3, 3, 2, 1],[1, 2, 3, 3, 2, 1],[1, 2, 2, 2, 2, 1],[1, 1, 1, 1, 1, 1]
]

对于每层,从左上方开始以顺时针的顺序填入所有元素。假设当前层的左上角位于 (top,left),右下角位于 (bottom,right),按照如下顺序填入当前层的元素。

    1. 从左到右填入上侧元素,依次为 (top,left) 到 (top,right)。
    2. 从上到下填入右侧元素,依次为 (top+1,right) 到 (bottom,right)。
    3. 如果 left<right 且 top<bottom,则从右到左填入下侧元素,依次为 (bottom,right−1) 到(bottom,left+1),以及从下到上填入左侧元素,依次为 (bottom,left) 到 (top+1,left)。

填完当前层的元素之后,将 left 和 top 分别增加 1,将 right 和 bottom 分别减少 1,进入下一层继续填入元素,直到填完所有元素为止。

class Solution {public int[][] generateMatrix(int n) {int num = 1;int[][] matrix = new int[n][n];int left = 0, right = n - 1, top = 0, bottom = n - 1;while (left <= right && top <= bottom) {for (int column = left; column <= right; column++) {matrix[top][column] = num;num++;}for (int row = top + 1; row <= bottom; row++) {matrix[row][right] = num;num++;}if (left < right && top < bottom) {for (int column = right - 1; column > left; column--) {matrix[bottom][column] = num;num++;}for (int row = bottom; row > top; row--) {matrix[row][left] = num;num++;}}left++;right--;top++;bottom--;}return matrix;}
}

参考资料

  1. problems/0059.螺旋矩阵II.md · programmercarl/leetcode-master(代码随想录出品) - Gitee.com
  2. 官方题解59. 螺旋矩阵 II - 力扣(LeetCode)

技巧 (Tip)

  1. 你的技术看起来很像初级

讲解为什么工作四五年的简历还不如校招时期

不能太老实,项目中没用过就不去学,实际上就算背会也算是你的一种本事。

2. 拼多多面试官笑了:“在什么情况下我应该选择抽象类而不是接口?反过来呢!”

抽象接口知识点

http://www.dtcms.com/wzjs/107090.html

相关文章:

  • 健身器材网站模板武汉seo软件
  • 穿越火线外挂购买网站中国网站建设公司前十名
  • 仙居网站建设贴吧浏览器看b站
  • 什么是企业型网站西安seo网站关键词优化
  • 怎么给网站做域名重定向怎么提升关键词的质量度
  • 专业专业的网站开发宁波seo推广优化公司
  • dw怎么把网站做的漂亮网站正能量免费推广软件
  • 西藏建设厅网站女教师网课入06654侵录屏
  • 萍乡做网站的公司常德政府网站
  • 元氏网站制作百度上做推广怎么做
  • 宁夏网站建设多少钱second是什么意思
  • wordpress导航页面模板下载地址南京seo圈子
  • 怎么做能让网站收录的快必应搜索
  • 网站建设和优化需要几个人网站推广优化网址
  • 光山网站建设网站模板价格
  • 素马网站建设费用差距互联网推广怎么找渠道
  • 网站建设要注册哪些商标类别互联网广告营销
  • 怎么创网站百度官网认证价格
  • 红豆梧州论坛seod的中文意思
  • 阿里云wordpress建站常州网络推广seo
  • 长沙岳麓区广告公司宁波seo哪家好快速推广
  • wordpress菜单不兼容关键词排名优化公司
  • 上海市建设安全协会网站孟 侠友情链接交换的方法
  • 沧州做网站推广公司百度怎么发布短视频
  • wordpress 邮件投稿信息流优化师简历模板
  • 旅游攻略网站模板seo博客
  • 大型网站 解决方案 技术网络营销有哪些形式
  • 今天西安最新通告短视频seo营销系统
  • 做网站做小程序推广杭州哪家seo公司好
  • 做外单网站亚马逊快手seo关键词优化