JavaScript數(shù)據(jù)結構之數(shù)組棧隊列

1. 數(shù)組

數(shù)組是平時使用最常用的數(shù)據(jù)結構,在JavaScript中數(shù)組是動態(tài)的分配大小,在這里我不會介紹JavaScript里面數(shù)組的所有的方法,而是針對數(shù)據(jù)結構這個方向談談所用到的方法。

1.1 創(chuàng)建和初始化數(shù)組

//創(chuàng)建空數(shù)組
var array = new Array();
//[]

//初始化數(shù)組
var array = new Array(1,2,3); 
var array = Array.of(1,2,3);//ES6的方法
//[1,2,3]

//創(chuàng)建大小為5的數(shù)組
var array = new Array();//ES6的方法
//[undefined,undefined,undefined,undefined,undefined]

//給數(shù)組賦值
var array = new Array();
array[0] = 1 ;
array[1] = 2 ;
array[2] = 3 ;
//[1,2,3]

1.2 添加元素

1.2.1往數(shù)組后添加元素

var number = [1,2,3];
number[number.length] = 4;
//[1,2,3,4]

//或者
var number = [1,2,3];
number.push(4);
//[1,2,3,4]

1.2.2往數(shù)組前面添加元素

var number = [1,2,3];
number.unshift(0);
//[0,1,2,3]
number.unshift(-2,-1);
//[-2,-1,0,1,2,3]

1.2.3往數(shù)組的任意位置插入元素

運用splice方法

//在索引1后面添加2,3,4
var number = [1,5,6];
number.splice(1,0,2,3,4);
//[1,2,3,4,5,6]

1.3 刪除元素

1.3.1 刪除第一位

var number = [1,2,3];
number.shift();
//[2,3]

1.3.2 刪除任意位置

使用splice方法刪除數(shù)組任意位置的元素

var numebr = [1,2,3,4,5,6];
//如果想刪除元素3
number.splice(2,1);
//[1,2,4,5,6]

//如果想刪除元素4,5
number.splice(3,2);

1.4 排序

1.4.1 反序

var number = [3,2,1];
number.reverse();
//[1,2,3]

1.4.2 自然排序

var numebr = [2,3,4,1,3,7];
number.sort();
//[1,2,3,3,4,7]

1.4.3 自定義排序

這個自定義排序跟java里面實現(xiàn)comparator接口一個意思。用處可大了。

var number = [4,5,6,7,1,2,3,8,9,10,11,12,13];
number.sort();
//[1, 10, 11, 12, 13, 2, 3, 4, 5, 6, 7, 8, 9]

仿佛看起有點不對啊,我們應該想要的是
[1,2,3,4,5,6,7,8,9,10,11,12,13],這個時候我們就用自定義排序來解決這個問題

var number = [4,5,6,7,1,2,3,8,9,10,11,12,13];

function compare(a,b){
    if(a < b){
        return -1;
    }
    if(a > b){
        return 1;
    }
    
    return 0;
}

number.sort(compare);
//[1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13]

這還只是最簡單的,也可以對任何對象類型進行數(shù)組排序。例如,對象Person有名字和年齡屬性,我們希望根據(jù)年齡排序

var friends = [{name:'李晨',age:40},{name:'范冰冰',age:35}];

function comparePerson(a,b){
    if(a.age < b.age){
        return  -1;
    }
    if(a.age > b.age){
        return 1;
    }
    return 0;
}

friends.sort(comparePerson);
//[{name:'范冰冰',age:35},{name:'李晨',age:40}]

1.5 搜索

搜索有兩個方法:indexOf方法返回與參數(shù)匹配的第一個元素的索引,lastIndexOf返回與參數(shù)匹配的最后一個元素的索引。

var number = [1,3,4,3,56,6,7,4];
number.indexOf(3);//1
number.lastIndexOf(3)//3

2. 棧

棧是一種遵循后進先出(LIFO)原則的有序集合。新添加的或待刪除的元素都保存在棧的末尾,稱作棧頂,另一端就叫棧底。在棧里,新元素都靠近棧頂,舊元素都接近棧底。在JavaScript中變量保存和函數(shù)調(diào)用都是用棧存儲的。

首先創(chuàng)建一個類來表示一個棧,需要一種數(shù)據(jù)結構來保存棧里的元素。這里我們就選擇剛學的數(shù)組:var items = [];
接下來,為我們的棧聲明一些方法:

  • push(elements(s)):添加一個(或幾個)新元素到棧頂
  • pop():移除棧頂?shù)脑兀瑫r返回被移除的元素
  • peek():獲取棧頂?shù)脑兀粚W龀鋈魏涡薷?/li>
  • isEmpty():如果棧里沒有任何元素就返回true,否則返回false;
  • clear():清空棧
  • size():返回棧元素的個數(shù)

如果上一節(jié)數(shù)組認真看了,我相信用JavaScript實現(xiàn)一個棧是非常簡單的。在這里就直接來代碼了,不用一個方法一個方法去解釋了。

function Stack(){
    var items = [];
    
    this.push = function(element){
        items.push(element);
    }
    
    this.pop = function(){
        return items.pop();
    }
    
    this.peek = function(){
        return items[items.length-1];
    }
    
    this.isEmpty = function(){
        return items.length === 0;
    }
    
    this.size = function(){
        return items.length;
    }
    
    this.clear = function(){
        items = [];
    }
    
    this.print = funciton(){
        console.log(items.toString());
    }
}

3. 隊列

隊列是遵循先來先服務(FIFO)原則的一組有序的項。隊列在尾部添加新元素,并從頂部移除元素。最新添加的元素排在隊列的末尾。

在現(xiàn)實生活中常見的例子就是排隊。
在計算機科學中,一個常見的例子就是打印隊列,先點擊打印的文檔會被先打印。

3.1 創(chuàng)建隊列

同樣先創(chuàng)建一個類來表示一個隊列。需要用到的數(shù)據(jù)結構同樣是數(shù)組var items = [];
聲明可用的方法:

  • enqueue(element(s)):向隊尾添加一個(或多個)新的項
  • dequeue():移除隊列的第一(即排在隊列最前面的)項,并返回被移除的元素。
  • front():返回隊列中第一個元素
  • isEmpty():如果隊列中不包含元素返回true,否則返回false
  • size():返回隊列包含元素的個數(shù)

完整的Queue類

function Queue(){
    var items = [];
    
    this.enqueue = function(element){
        items.push(element);
    }
    
    this.dequeue = function(){
        return items.shift();
    }
    
    this.front = function(){
        return items[0];
    }
    
    this.isEmpty = function(){
        return items.length === 0;
    }
    
    this.clear = function(){
        items = [];
    }
    
    this.size = funciton(){
        return items.length;
    }
    
    this.print = function(){
        console.log(items.toString());
    }
}

3.2 優(yōu)先隊列

在優(yōu)先隊列中,元素被賦予優(yōu)先級。當訪問元素的時,具有最高優(yōu)先級的元素先刪除。優(yōu)先隊列具有最高進先出的行為特征。例如:醫(yī)院的急救室為病人賦予優(yōu)先級(這個優(yōu)先級可以指病情嚴重的成程度),具有最高優(yōu)先級的病人最先得到治療。

實現(xiàn)一個優(yōu)先隊列有兩種選項:

  1. 設置優(yōu)先級,然后在正確的位置添加元素;
  2. 用入列操作添加元素,然后按照優(yōu)先級移除它們。

我們這里采用第一種。

function PriorityQueue(){
    var items = [];
    
    funciton QueueElement(element,priority){
        this.element = element;
        this.priority = priority;
    }
    
    function comparePriority(a,b){
        if(a.priority > b.priority){
            return 1;
        }
        
         if(a.priority < b.priority){
            return -1;
        }
        
        return 0;
    }
    
    this.enqueue = funciton(element,priority){
        var queueElement = new QueueElement(element,priority);
        
        items.push(queueElement);
        
        items.sort(comparePriority);
    }
    
    //其它方法和默認的Queue實現(xiàn)相同
}

當然,這個enqueue的實現(xiàn)方法很多種,我這效率不是最高的,但是容易理解。將插入的元素根據(jù)優(yōu)先級排個序,那么先出去的就是優(yōu)先級最高的了。

這幾個數(shù)據(jù)結構比較簡單,所以我沒有舉例子,下一次分享的是鏈表,敬請期待!最后歡迎訪問我的個人站點

最后編輯于
?著作權歸作者所有,轉載或內(nèi)容合作請聯(lián)系作者
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 228,238評論 6 531
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 98,430評論 3 415
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 176,134評論 0 373
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經(jīng)常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 62,893評論 1 309
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 71,653評論 6 408
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 55,136評論 1 323
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,212評論 3 441
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,372評論 0 288
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 48,888評論 1 334
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 40,738評論 3 354
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 42,939評論 1 369
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,482評論 5 359
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 44,179評論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,588評論 0 26
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,829評論 1 283
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,610評論 3 391
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 47,916評論 2 372

推薦閱讀更多精彩內(nèi)容

  • java筆記第一天 == 和 equals ==比較的比較的是兩個變量的值是否相等,對于引用型變量表示的是兩個變量...
    jmychou閱讀 1,508評論 0 3
  • 1.棧 1.1.棧的定義 棧(stack)是限定僅在表尾(棧頂 top)進行插入和刪除操作的后進先出的線性表。 p...
    JonyFang閱讀 1,379評論 0 21
  • 1 序 2016年6月25日夜,帝都,天下著大雨,拖著行李箱和同學在校門口照了最后一張合照,搬離寢室打車去了提前租...
    RichardJieChen閱讀 5,115評論 0 12
  • 棧 棧的英文單詞是Stack,它代表一種特殊的線性表,這種線性表只能在固定一端(通常認為是線性表的尾端)進行插入,...
    Jack921閱讀 1,514評論 0 5
  • 我天性不宜交際。在多數(shù)場合,我不是覺得對方乏味,就是害怕對方覺得我乏味。可是我既不愿忍受對方的乏味,也不愿費...
    CM格兒閱讀 208評論 0 0