javascript中活靈活現(xiàn)的Array對象詳解
前言
JavaScript中的Array對象,就是我們常說的數(shù)組對象,主要用于封裝多個任意類型的數(shù)據(jù),并對它們進(jìn)行管理。
所有主流瀏覽器均支持Array對象。
大家都知道Array實(shí)例有這四個方法:push、pop、shift、unshift。大家也都知道 push + pop實(shí)現(xiàn)棧, shift + push實(shí)現(xiàn)隊(duì)列。在這里不討論什么先進(jìn)后出、先進(jìn)先出。
但一面這個題將要用到這幾個方法。
題目
螺旋矩陣這個名詞,在后臺語言中可能很熟悉,他是個二維數(shù)組,他有什么特點(diǎn)呢?請看下圖:
以上是一個從外到內(nèi)的螺旋矩陣,他的排列規(guī)則是從外圍開始走,一圈一圈繞道最里面,就像一條盤旋著的蛇。
分析與解答
進(jìn)入正題,今年9月份騰訊校招在線筆試題就有一個螺旋矩陣的 題,傳入給定數(shù)字n,打印出n*n的螺旋矩陣,當(dāng)時本菜鳥并沒有做出來,時間過后自己在電腦上想,然后恍然大悟明白的其中的奧妙。
雖然博主沒有記錄當(dāng)時的代碼,但是我是首先定義了個n*n的二維數(shù)組,得到需要繞幾層,比如上面的是2層,然后就循環(huán)幾次,在內(nèi)部用四個for循環(huán),分別是上下左右給定義的二維數(shù)組插內(nèi)容,具體的代碼就沒法上了,反正方法很笨,而且并不是本文章的重點(diǎn),下面進(jìn)入本章主題:
前幾天我在codewars上做題,遇到了個螺旋矩陣的題,它是要求寫一個函數(shù),給定一個矩陣二維數(shù)組參數(shù),返回一個數(shù)組,該數(shù)組的元素順序就是螺旋矩陣的路徑。
例如:
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函數(shù)是將傳入的‘螺旋矩陣'用一維數(shù)組按順序輸出了(我也不知道怎么說了,反正就是把這個二維數(shù)組像蛇一樣盤旋著形成一維數(shù)組)
看到這個題的第一時間,我就想起了騰訊校招的那個題, 然后博主就用類似的四個for循環(huán)寫完了,然后提交。這個網(wǎng)站有個功能是,你做完題目可以看別人做的代碼,博主小心翼翼的點(diǎn)開答案列表,哇,第一條就深深吸引了我。雖然不記得別人寫的源碼,但大致是這樣的:
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 }
對于菜鳥級別的我來說,剛開始還有點(diǎn)懵,因?yàn)楦业乃季S不一樣,看了一會才發(fā)現(xiàn)其中的奧妙。相比我寫的真是好多了,這個代碼不需要考慮傳入的是否為n*n數(shù)組,他可以解析任意數(shù)組比如2*3數(shù)組等。
而且代碼絕對簡潔,對于有一定基礎(chǔ)的來說也很容易懂。
如果你有些困惑,就往下看,我的圖文解釋
// 上 linear = linear.concat(item)
item為二維數(shù)組的第一個元素,就是第一個數(shù)組,將它移除數(shù)組并返回,如下:
此行代碼后,原數(shù)組變成如下:
接下來,我們需要將 5 6 7 加入要返回的數(shù)組中,也就是二維數(shù)組的每個數(shù)組元素的最后一個元素,我們可以用pop獲取到:
// 右 for (var i = 0; i < spiral.length; i++) { linear.push( spiral[i].pop() ) }
這時原來的二維數(shù)組變成了如下:
接下來我們要拿到最后一行 10 9 8 并倒置,將二維數(shù)組pop出最后一個數(shù)組然后將他reverse就可以了
// 下 linear = linear.concat(spiral.pop().reverse())
此時原來二維數(shù)組是這樣的:
獲取左邊的就跟右邊類似,只需要將pop變成shift:
// 左 for (var i = spiral.length - 1; i >= 0; i --) { linear.push(spiral[i].shift()) }
原來二維數(shù)組變?yōu)椋?/p>
此時,一圈就完了,然后while判斷是否進(jìn)入下一圈。
總結(jié)
好了,本文的內(nèi)容就到這里了,一個看上去不簡單的題目,在Array的靈活下變得如此簡單,希望本文的內(nèi)容對各位js新手們能有所幫助,如果有疑問大家可以留言交流。
- 以JSON形式將JS中Array對象數(shù)組傳至后臺的方法
- JavaScript 判斷判斷某個對象是Object還是一個Array
- js中判斷Object、Array、Function等引用類型對象是否相等
- JavaScript數(shù)組Array對象增加和刪除元素方法總結(jié)
- Javascript中判斷變量是數(shù)組還是對象(array還是object)
- javascript Array對象使用小結(jié)
- JScript內(nèi)置對象Array中元素的刪除方法
- js Array對象的擴(kuò)展函數(shù)代碼
- JavaScript中Array 對象相關(guān)的幾個方法
- JavaScript中的Array對象使用說明
相關(guān)文章
在Node.js中使用Javascript Generators詳解
下面小編就為大家?guī)硪黄贜ode.js中使用Javascript Generators詳解。小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考2016-05-05微信小程序?qū)崿F(xiàn)用戶登錄模塊服務(wù)器搭建
這篇文章主要介紹了微信小程序?qū)崿F(xiàn)用戶登錄模塊服務(wù)器搭建,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-05-05JS中隊(duì)列和雙端隊(duì)列實(shí)現(xiàn)及應(yīng)用詳解
這篇文章主要介紹了JS中隊(duì)列和雙端隊(duì)列實(shí)現(xiàn)及應(yīng)用,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-09-09Bootstrap 模態(tài)框(Modal)帶參數(shù)傳值實(shí)例
模態(tài)框(Modal)是覆蓋在父窗體上的子窗體。下面通過本文給大家介紹Bootstrap 模態(tài)框(Modal)帶參數(shù)傳值實(shí)例代碼,需要的朋友參考下吧2017-08-08networkInformation.downlink測用戶網(wǎng)速方法詳解
這篇文章主要為大家介紹了networkInformation.downlink測用戶網(wǎng)速方法詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-05-05JavaScript學(xué)習(xí)總結(jié)之正則的元字符和一些簡單的應(yīng)用
這篇文章主要介紹了JavaScript學(xué)習(xí)總結(jié)之正則的元字符和一些簡單的應(yīng)用,需要的朋友可以參考下2017-06-06純javascript實(shí)現(xiàn)四方向文本無縫滾動效果
本文主要給大家分享了使用純javascript實(shí)現(xiàn)的可控制的四方向文本無縫滾動的代碼,效果非常不錯,有需要的小伙伴可以參考下。2015-06-06