Spiral Matrix I II

Spiral Matrix I

Given an integer n, generate a square matrix filled with elements from 1 to n^2 in spiral order.

Example

Given n = 3,

You should return the following matrix:

[[ 1, 2, 3 ],[ 8, 9, 4 ],[ 7, 6, 5 ]
]

分析:
从上,右,下,左打印。
 1 public class Solution {
 2     /**
 3      * @param n an integer
 4      * @return a square matrix
 5      */
 6     public int[][] generateMatrix(int n) {
 7         
 8         int[][] arr = new int[n][n];
 9         int a = 0;
10         int b = n - 1;
11         int k = 1;
12         
13         while (a < b) {
14             for (int i = a; i <= b; i++) {
15                 arr[a][i] = k++;
16             }
17             
18             for (int i = a + 1 ; i <= b - 1; i++) {
19                 arr[i][b] = k++;
20             }
21             
22             for (int i = b ; i >= a; i--) {
23                 arr[b][i] = k++;
24             }
25             
26             for (int i = b - 1 ; i >= a + 1; i--) {
27                 arr[i][a] = k++;
28             }
29             
30             a++;
31             b--;
32         }
33         
34         if (a == b) {
35             arr[a][b] = k; 
36         }
37         return arr;
38     }
39 }

 

Spiral Matrix II

Given a matrix of m x n elements (m rows, n columns), return all elements of the matrix in spiral order.

Example

Given the following matrix:

[[ 1, 2, 3 ],[ 4, 5, 6 ],[ 7, 8, 9 ]
]

You should return [1,2,3,6,9,8,7,4,5].

分析:

拿到左上角和右下角的坐标,然后从上,右,下,左打印。然后更新坐标。

 1 public class Solution {
 2     public List<Integer> spiralOrder(int[][] matrix) {
 3         List<Integer> list = new ArrayList<>();
 4         
 5         if (matrix == null || matrix.length == 0 || matrix[0].length == 0) return list;
 6         int a = 0, b = 0;
 7         int x = matrix.length - 1, y = matrix[0].length - 1;
 8         
 9         while (a <= x && b <= y) {
10             // top row
11             for (int i = b; i <= y; i++) {
12                 list.add(matrix[a][i]);
13             }
14             // right column
15             for (int i = a + 1; i <= x - 1; i++) {
16                 list.add(matrix[i][y]);
17             }
18             // bottom row
19             if (a != x) {
20                 for (int i = y; i >= b; i--) {
21                     list.add(matrix[x][i]);
22                 }
23             }
24             // left column
25             if (b != y) {
26                 for (int i = x - 1; i >= a + 1; i--) {
27                     list.add(matrix[i][b]);
28                 }
29             }
30             
31             a++;
32             b++;
33             x--;
34             y--;
35         }
36         return list;
37     }
38 }

 

转载于:https://www.cnblogs.com/beiyeqingteng/p/5680666.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/470380.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

二、express中间件

一、中间件引入 实现加入日志模块功能&#xff1a; 1. 我们能想到的方案&#xff1a; 将日志输出代码封装到函数中&#xff0c;然后需要日志输出的地方调用这个函数即可。 app.js文件&#xff1a; const express require(express)const app express()const myLogger (r…

移动端中如何检测设备方向的变化?

除非你的应用程序限定了只在移动设备直立状态或水平状态下使用&#xff0c;一般情况下&#xff0c;你需要调整一些设定。即便你设计的布局流畅时尚&#xff0c;你可能需要改变某些编程代码。通常有以下一些小的策略用于检测移动设备方向的改变。 orientationchange事件 你等待一…

python函数名与变量名可以一样吗_python--第一类对象,函数名,变量名

一 . 第一类对象函数对象可以像变量一样进行赋值 , 还可以作为列表的元素进行使用可以作为返回值返回 , 可以作为参数进行传递def func():def people():print(金_卡戴珊)print(oh,yes!)print(oh,baby!)return peopleret func()ret()二 . 闭包闭包 -> 函数的嵌套内层函数对外…

Mac Pro 修改环境变量

参考&#xff1a;Ubuntu 12 修改环境变量 【实战】 把 php、php-fpm、nginx、mysql 的相关命令路径添加到 用户环境变量 $ vim ~/.bash_profile alias llls -alF alias lals -A alias lls -CFexport GOROOT/usr/local/go export GOPATH/Users/jianbao/GoProjects/go-studyexpor…

三、Express 路由

一、路由 路由是指应用程序的端点(URI)如何响应客户端请求. 你可以使用app与HTTP方法相对应的Express对象的方法来定义路由. 例如,app.get()处理GET请求和app.post POST 请求。 你还可以使用app.all()处理所有HTTP方法,并使用app.use()将中间件指定为回调函数. 这些路由方法…

python程序操作的核心_python核心编程-第五章-个人笔记

1.用del删除对对象的引用>>> a 123>>>a123>>> dela>>>aTraceback (most recent call last):File"", line 1, in NameError : namea is not defined2.整型(1)布尔型 该类型取值范围只要两个值&#xff1a;布尔值True 和 布尔…

辅助同步器

java除了提供锁之外&#xff0c;还提供了一些辅助的同步器。 一、CountDownLatch 作用&#xff1a;常常要有一个线程&#xff08;master&#xff09;做汇总&#xff0c;等n个子步骤&#xff08;线程slave&#xff09;完成后才能继续操作。用join写只能等子线程完成&#xff0c;…

RESTful 接口设计规范

一、RESTful 接口设计规范 1. 协议 API与用户的通信协议&#xff0c;尽量使用HTTPs协议。 2. 域名 应该尽量将API部署在专用域名之下。 https://api.example.com 如果确定API很简单&#xff0c;不会有进一步扩展&#xff0c;可以考虑放在主域名下。 https://example.org/ap…

是引进外部函数吗_使用PowerBI的这两个函数,灵活计算各种占比

计算个体占总体的比例是一个很常见的分析方式&#xff0c;它很简单&#xff0c;就是两个数字相除&#xff0c;但是当需要计算的维度、总体的范围发生动态变化时&#xff0c;如何灵活且快速的计算出各种占比&#xff0c;还是需要动一点心思的。本文就通过 DAX 中的 ALL 和 ALLSE…

WCF入门(五)---创建WCF服务

使用Microsoft Visual Studio2012创建WCF服务&#xff0c;理解如下所有必要的编码&#xff0c;更好地创建WCF服务的概念&#xff0c;这里做一个简单的任务。 启动Visual Studio 2012。 单击新建项目&#xff0c;然后在Visual C&#xff03;标签&#xff0c;选择WCF选项。 WCF服…

Express接口综合案例(创建项目、配置常用中间件、路由设计、提取控制器模块、配置错误统一处理中间件、用户注册的数据验证,密码加密)

一、创建项目 二、目录结构 三、配置常用中间件 3.1 解析请求体 express.json&#xff08;&#xff09;express.urlencoded&#xff08;&#xff09; 3.2 日志输出 morgan&#xff08;&#xff09; 3.3 为客户端提供跨域资源请求 cors&#xff08;&#xff09; 四、路…

二进制包如何知道go 版本_gops 是怎么和 Go 的运行时进行交互的?

本文基于 Go 1.13 和 gops 0.3.7.gops 旨在帮助开发人员诊断 Go 流程并与之交互。它提供了跟踪运行中的程序几秒钟的功能&#xff0c;可以通过获取 CPU 配置文件 pprof&#xff0c;甚至可以直接与垃圾收集器进行交互。发现gops 提供发现服务&#xff0c;该服务能够列出计算机上…

在VMware开启此虚拟机时出现内部错误

在开启此虚拟机时&#xff0c;总是出现“内部错误“&#xff0c;是因为任务管理器的服务里的VMwareHostd已经停止了&#xff0c;所以需要开启它 步骤&#xff1a;打开任务管理器——》服务——》VMwareHostd 转载于:https://www.cnblogs.com/t0404/p/10291013.html

基于JWT的身份认证学习笔记

JSON Web Token&#xff08;缩写JWT&#xff09;是目前最流行的跨域认证解决方案。 一、跨域认证的问题 互联网服务离不开用户认证。一般流程是下面这样。 1、用户向服务器发送用户名和密码。 2、服务器验证通过后&#xff0c;在当前对话&#xff08;session&#xff09;里面保…

ssh 端口_【科普】SSH都不懂,还搞什么网络

今天小编为大家分享一篇关于SSH 的介绍和使用方法的文章。本文从SSH是什么出发&#xff0c;讲述了SSH的基本用法&#xff0c;之后在远程登录、端口转发等多种场景下进行独立的讲述&#xff0c;希望能对大家有所帮助。1. 什么是SSH&#xff1f;SSH是一种网络协议&#xff0c;用于…

二维码扫描和应用跳转

转载自&#xff1a; http://sindrilin.com/ios-dev/2015/11/01/二维码扫描和应用跳转.html 前面我们已经调到过怎么制作二维码&#xff0c;在我们能够生成二维码之后&#xff0c;如何对二维码进行扫描呢&#xff1f; 在iOS7之前&#xff0c;大部分应用中使用的二维码扫描是第三…

oracle 锁表如何解决_Java高并发解决什么方式

对于我们开发的网站&#xff0c;如果网站的访问量非常大的话&#xff0c;那么我们就需要考虑相关的并发访问问题了。而并发问题是绝大部分的程序员头疼的问题&#xff0c;但话又说回来了&#xff0c;既然逃避不掉&#xff0c;那我们就坦然面对吧~今天就让我们一起来研究一下常见…

Express接口案例 使用jsonwebtoken

一、jsonwebtoken的使用 jsonwebtoken官方文档 const jwt require(jsonwebtoken) // 以同步的方式&#xff0c;生成jwt // const token jwt.sign({ // foo: bar // }, zepzepep)// 以异步的方式&#xff0c;生成jwt const token jwt.sign({foo: bar }, zepzepep, (err, …

php 日期转毫秒_【小技巧】 各种日期操作方法汇总

虽然现在处理日期方面已经有了很成熟的也很好用的库&#xff0c;例如(momentjs和date-fns)&#xff0c;但是在实际开发中&#xff0c;我们有时候可能并不需要整个库。所以我就在下面整理了在前端开发时对日期时间的各种操作&#xff0c;也算是比较全的了。其中一部分来自自己&a…

JavaScript事件使用指南

事件流 事件流描述的是从页面中接收事件的顺序&#xff0c;IE和Netscape提出来差不多完全相反的事件流的概念&#xff0c;IE事件流是事件冒泡流&#xff0c;Netscape事件流是事件捕获流。事件冒泡 IE的事件流叫做事件冒泡&#xff0c;即事件开始时由最具体的元素(文档中嵌套最深…