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

微信分销商城东莞百度seo排名

微信分销商城,东莞百度seo排名,php网站建设流程,php个人网站模板题目 输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字。 示例 1: 输入:matrix [[1,2,3],[4,5,6],[7,8,9]] 输出:[1,2,3,6,9,8,7,4,5]示例 2: 输入:matrix [[1,2,3,4],[5,6,7,8],[9,10,1…

题目

输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字。

示例 1:

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

示例 2:

输入:matrix = [[1,2,3,4],[5,6,7,8],[9,10,11,12]]
输出:[1,2,3,4,8,12,11,10,9,5,6,7]

剑指 Offer 29. 顺时针打印矩阵 - 力扣(LeetCode)

与 力扣54题相同

54. 螺旋矩阵

思路

二维数组顺时针从外往里走

可以想象成:按照 右-》下-》左 -》上 的顺序一直走,走过的地方不要走即可。

1. 每走过一个地方,就标记一下,这样下次就不会再走这里了

2. 循环往右走,直到不能走为止(不能走:既不超出数组边界,并且下一个地方没有走过的标记)

3. 循环往下走,直到不能走为止

4. 循环往左走,直到不能走为止

5. 循环往上走,直到不能走为止

6. 重复2345这四步,直到四面八方没有一个地方可以走

代码

class Solution {public int[] spiralOrder(int[][] matrix) {int i = 0;int j = 0;int m = matrix.length;if (m == 0)return new int[0];int n = matrix[0].length;int passingFlag = Integer.MIN_VALUE;int res [] = new int[m * n];int p = 0;res[p] = matrix[i][j];matrix[i][j] = passingFlag;//上下左右有一个地方能走就行while ((j+1< n && matrix[i][j+1] != passingFlag)||  (i+1< m && matrix[i+1][j] != passingFlag) || (j - 1 >= 0 && matrix[i][j - 1] != passingFlag) || (i - 1 >= 0 && matrix[i-1][j] != passingFlag)){//往右走while (j+1< n && matrix[i][j+1] != passingFlag){j = j + 1;p++;res[p] = matrix[i][j];matrix[i][j] = passingFlag;}//往下走while (i+1< m && matrix[i+1][j] != passingFlag){i = i + 1 ;p++;res[p] = matrix[i][j];matrix[i][j] = passingFlag;}//往左走while (j - 1 >= 0 && matrix[i][j - 1] != passingFlag){j = j - 1;p++;res[p] = matrix[i][j];matrix[i][j] = passingFlag;}//往上走while (i - 1 >= 0 && matrix[i-1][j] != passingFlag){i = i - 1;p++;res[p] = matrix[i][j];matrix[i][j] = passingFlag;}}return res;}
}

效果

可以优化的地方:

1.走过标记

        走过的标记,这里我使用的是:走过一个地方就让那里变成最小值Integer.MIN_VALUE,但是这么做不严谨,因为测试例子里没有走过最小值,所以我通过了。

        官方的做法是:用一个辅助矩阵,也就是再做一个二维数组,走过原数组,就在辅助数组上标记一下,这么做才合情合理。

2.结束条件

        判断外层大循环结束,我的条件是只要四面八方都不能走了,就停止。

        官方的结束条件是,只要结果数组满了,就结束。

        这样看来 官方的解法要比我少判断一些东西。

也就是将

        while ((j+1< n && matrix[i][j+1] != passingFlag)||  (i+1< m && matrix[i+1][j] != passingFlag) || (j - 1 >= 0 && matrix[i][j - 1] != passingFlag) || (i - 1 >= 0 && matrix[i-1][j] != passingFlag)){

替换成

        while (p+1 < m*n){

代码会简洁很多

http://www.dt0577.cn/news/30916.html

相关文章:

  • 如何再网站上做免费广告词酒店如何进行网络营销
  • 昆明网站建设百度站长
  • 学广告专业我后悔了sem优化托管
  • 什么是网站死链微信裂变营销软件
  • 企业电商网站优化百度开户流程
  • 做海鲜批发去哪个网站品牌服务推广
  • 做网站的公司应该税率多少百度有免费推广广告
  • 织梦做网站需要钱吗网站怎么让百度收录
  • 网站添加搜索旺道seo软件
  • 网站软件有哪些企业营销
  • 网站空间的选择seo虚拟外链
  • 摄影网站功能设计西安快速排名优化
  • 网站类别页面怎么做cpv广告联盟
  • 做网站的网页设计用cdr吗小吃培训机构排名前十
  • 重庆网站建设的价格低百度官网入口链接
  • 家装设计网站怎么做信息流广告素材网站
  • 国内vps做网站备案站长之家怎么用
  • wordpress主题制作实例做seo推广公司
  • 建设安全协会网站国外推广渠道平台
  • 孟州网站开发app好看的网站模板
  • 新型h5网站建设如何做营销策划方案
  • 哪些网站可以免费做h5sem是什么职业
  • 个人能接做网站的活么软文素材
  • wordpress 百度主动推送seo监控系统
  • 织梦做的网站首页打不开百度下载2021新版安装
  • 去哪里找人做网站优化设计三年级上册答案
  • 建设项目验收公示网站宁波网站推广优化公司怎么样
  • 经营性网站备案条件开封网站优化公司
  • 网站建设 软件开发武汉seo推广优化公司
  • 帆客建设网站app推广赚钱平台