javascript中活灵活现的Array对象详解


Posted in Javascript onNovember 30, 2016

前言

JavaScript中的Array对象,就是我们常说的数组对象,主要用于封装多个任意类型的数据,并对它们进行管理。

所有主流浏览器均支持Array对象。

大家都知道Array实例有这四个方法:push、pop、shift、unshift。大家也都知道 push + pop实现栈, shift + push实现队列。在这里不讨论什么先进后出、先进先出。

但一面这个题将要用到这几个方法。

题目

螺旋矩阵这个名词,在后台语言中可能很熟悉,他是个二维数组,他有什么特点呢?请看下图:

javascript中活灵活现的Array对象详解

以上是一个从外到内的螺旋矩阵,他的排列规则是从外围开始走,一圈一圈绕道最里面,就像一条盘旋着的蛇。

分析与解答

进入正题,今年9月份腾讯校招在线笔试题就有一个螺旋矩阵的 题,传入给定数字n,打印出n*n的螺旋矩阵,当时本菜鸟并没有做出来,时间过后自己在电脑上想,然后恍然大悟明白的其中的奥妙。

虽然博主没有记录当时的代码,但是我是首先定义了个n*n的二维数组,得到需要绕几层,比如上面的是2层,然后就循环几次,在内部用四个for循环,分别是上下左右给定义的二维数组插内容,具体的代码就没法上了,反正方法很笨,而且并不是本文章的重点,下面进入本章主题:

前几天我在codewars上做题,遇到了个螺旋矩阵的题,它是要求写一个函数,给定一个矩阵二维数组参数,返回一个数组,该数组的元素顺序就是螺旋矩阵的路径。

例如:

function getLinear (spiral) {
 //...做一些操作 
}

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

getLinear(arr) // 返回 [1,2,3,6,9,8,7,4,5]

上面例子清除的看到getLinear函数是将传入的‘螺旋矩阵'用一维数组按顺序输出了(我也不知道怎么说了,反正就是把这个二维数组像蛇一样盘旋着形成一维数组)

看到这个题的第一时间,我就想起了腾讯校招的那个题, 然后博主就用类似的四个for循环写完了,然后提交。这个网站有个功能是,你做完题目可以看别人做的代码,博主小心翼翼的点开答案列表,哇,第一条就深深吸引了我。虽然不记得别人写的源码,但大致是这样的:

function getLinear(spiral) {

  var item;

  var linear = []

  while (item = spiral.shift()) {
  // 上
  linear = linear.concat(item)

  // 右
  for (var i = 0; i < spiral.length; i++) {
   linear.push( spiral[i].pop() )
  }

  // 下
  linear = linear.concat( spiral.pop().reverse())

  // 左
  for (var i = spiral.length - 1; i >= 0; i --) {
   linear.push(spiral[i].shift())
  }

  }
  return linear
 }

对于菜鸟级别的我来说,刚开始还有点懵,因为跟我的思维不一样,看了一会才发现其中的奥妙。相比我写的真是好多了,这个代码不需要考虑传入的是否为n*n数组,他可以解析任意数组比如2*3数组等。

而且代码绝对简洁,对于有一定基础的来说也很容易懂。

如果你有些困惑,就往下看,我的图文解释

// 上
 linear = linear.concat(item)

item为二维数组的第一个元素,就是第一个数组,将它移除数组并返回,如下:

javascript中活灵活现的Array对象详解

此行代码后,原数组变成如下:

javascript中活灵活现的Array对象详解

接下来,我们需要将 5 6 7 加入要返回的数组中,也就是二维数组的每个数组元素的最后一个元素,我们可以用pop获取到:

// 右
  for (var i = 0; i < spiral.length; i++) {
   linear.push( spiral[i].pop() )
  }

这时原来的二维数组变成了如下:

javascript中活灵活现的Array对象详解

接下来我们要拿到最后一行 10 9 8 并倒置,将二维数组pop出最后一个数组然后将他reverse就可以了

// 下
 linear = linear.concat(spiral.pop().reverse())

此时原来二维数组是这样的:

javascript中活灵活现的Array对象详解

获取左边的就跟右边类似,只需要将pop变成shift:

// 左
for (var i = spiral.length - 1; i >= 0; i --) {
 linear.push(spiral[i].shift())
}

原来二维数组变为:

javascript中活灵活现的Array对象详解

此时,一圈就完了,然后while判断是否进入下一圈。

总结

好了,本文的内容就到这里了,一个看上去不简单的题目,在Array的灵活下变得如此简单,希望本文的内容对各位js新手们能有所帮助,如果有疑问大家可以留言交流。

Javascript 相关文章推荐
jquery each的几种常用的使用方法示例
Jan 21 Javascript
jQuery插件Elastislide实现响应式的焦点图无缝滚动切换特效
Apr 12 Javascript
JavaScript实现删除,移动和复制文件的方法
Aug 05 Javascript
Jquery插件之Fancybox丰富的弹出层效果附源码下载
Dec 02 Javascript
JavaScript驾驭网页-获取网页元素
Mar 24 Javascript
详解Vue快速零配置的打包工具——parcel
Jan 16 Javascript
vue2.0在没有dev-server.js下的本地数据配置方法
Feb 23 Javascript
在 Linux/Unix 中不重启 Vim 而重新加载 .vimrc 文件的流程
Mar 21 Javascript
vue源码解析之事件机制原理
Apr 21 Javascript
使用Vue的slot插槽分发父组件内容实现高度复用、更加灵活的组件(推荐)
May 01 Javascript
简单了解Vue + ElementUI后台管理模板
Apr 07 Javascript
JS将指定的某个字符全部转换为其他字符实例代码
Oct 13 Javascript
如何处理JSON中的特殊字符
Nov 30 #Javascript
Angular.JS判断复选框checkbox是否选中并实时显示
Nov 30 #Javascript
Node.js开发教程之基于OnceIO框架实现文件上传和验证功能
Nov 30 #Javascript
浅析JavaScript中break、continue和return的区别
Nov 30 #Javascript
JavaScript的变量声明提升问题浅析(Hoisting)
Nov 30 #Javascript
浅析script标签中的defer与async属性
Nov 30 #Javascript
JavaScript 字符串常用操作小结(非常实用)
Nov 30 #Javascript
You might like
优化NFR之一 --MSSQL Hello Buffer Overflow
2006/10/09 PHP
用PHP和ACCESS写聊天室(三)
2006/10/09 PHP
php利用iframe实现无刷新文件上传功能的代码
2011/09/29 PHP
PHP编码规范的深入探讨
2013/06/06 PHP
php实现可以设置中奖概率的抽奖程序代码分享
2014/01/19 PHP
php使用fopen创建utf8编码文件的方法
2014/10/31 PHP
php代码架构的八点注意事项
2016/01/25 PHP
Jquery为单选框checkbox绑定单击click事件
2012/12/18 Javascript
关于onchange事件在IE和FF下的表现及解决方法
2014/03/08 Javascript
javascript 兼容各个浏览器的事件
2015/02/04 Javascript
javascript+html5实现仿flash滚动播放图片的方法
2015/04/27 Javascript
AngularJS向后端ASP.NET API控制器上传文件
2016/02/03 Javascript
推荐三款不错的图片压缩上传插件(webuploader、localResizeIMG4、LUploader)
2017/04/21 Javascript
jquery中有哪些api jQuery主要API
2017/11/20 jQuery
vue、react等单页面项目应该这样子部署到服务器
2018/01/03 Javascript
JS从非数组对象转数组的方法小结
2018/03/26 Javascript
jquery 验证用户名是否重复代码实例
2019/05/14 jQuery
Kettle中使用JavaScrip调用jar包对文件内容进行MD5加密的操作方法
2020/09/04 Javascript
微信小程序实现翻牌抽奖动画
2020/09/21 Javascript
python生成随机验证码(中文验证码)示例
2014/04/03 Python
python魔法方法-自定义序列详解
2016/07/21 Python
基于Django模板中的数字自增(详解)
2017/09/05 Python
在Python dataframe中出生日期转化为年龄的实现方法
2018/10/20 Python
使用Django xadmin 实现修改时间选择器为不可输入状态
2020/03/30 Python
拿来就用!Python批量合并PDF的示例代码
2020/08/10 Python
浅析Python 责任链设计模式
2020/09/11 Python
REN Clean Skincare官网:英国本土有机护肤品牌
2019/02/23 全球购物
什么是反射?如何实现反射?
2016/07/25 面试题
青年志愿者活动总结
2014/04/26 职场文书
孩子教育的心得体会
2014/09/01 职场文书
法制演讲稿
2014/09/10 职场文书
退休党员个人对照检查材料思想汇报
2014/09/29 职场文书
工厂见习报告范文
2014/10/31 职场文书
保证书格式
2015/01/16 职场文书
2015年房产销售工作总结范文
2015/05/22 职场文书
如何写观后感
2015/06/19 职场文书