JavaScript 鏈表,實(shí)現(xiàn)增菱阵、刪踢俄、查功能(學(xué)習(xí)筆記)

JS

Java Scrip是一門(mén)非常常用的網(wǎng)頁(yè)語(yǔ)言,有著彪悍可愛(ài)的歷史晴及。

JS鏈表實(shí)現(xiàn)

注:這里是對(duì)于這個(gè)網(wǎng)頁(yè)的學(xué)習(xí)筆記

新建一個(gè)類(lèi)
    function Node(data)//
 {
         this.data = data;
         this.next = null;
}

這里的操作類(lèi)似于一個(gè)函數(shù)都办,將參數(shù)傳進(jìn)來(lái)之后,生成一個(gè)鏈表類(lèi)

    function List()
    {
this.head = new Node('head');//相當(dāng)于一個(gè)構(gòu)造函數(shù)
   //類(lèi)似C++中的成員函數(shù)
 this.find = find;
this.insert = insert;
 this.display = display;
this.remove = remove;}

這里的操作和創(chuàng)建C++的成員函數(shù)很像虑稼,這里的函數(shù)都會(huì)在后文中定義

插入新的數(shù)據(jù)+查找功能
  function insert(newData, item) {
var newNode = new Node(newData);
var currNode = this.find(item);
newNode.next = currNode.next;
currNode.next = newNode;}

item參數(shù):這里是決定插入到哪一個(gè)的后面琳钉,item和data的數(shù)據(jù)類(lèi)型一致
var newNode :創(chuàng)建了一個(gè)新的鏈表類(lèi)型數(shù)據(jù),以便插入到鏈表中
var currNode:找到“item“所在的位置动雹,插入到它的后面

所以就有一個(gè)需要解決的問(wèn)題槽卫,如何找到”item“所在的位置,于是我們定義了find()函數(shù)胰蝠。

  function find(item)
 {
var currNode = this.head;
while(currNode.data !=item)
{
    currNode = currNode.next;
}
return currNode;}

這里的其實(shí)是一個(gè)遍歷的操作歼培,直到找到和item值相符的數(shù)值才停下來(lái)。我們?cè)谶@里也把查找功能給實(shí)現(xiàn)了茸塞。

刪除數(shù)據(jù)
function remove(item) {
    var prevNode = findPrev(item) ;
    if (!(prevNode.next == null)) {
        prevNode.next = prevNode.next.next; 
        prevNode.next.data = prevNode.next.next.data;
    }
}

prevNode 參數(shù):來(lái)找到躲庄,需要?jiǎng)h除的數(shù)據(jù),的前一個(gè)數(shù)據(jù)
再通過(guò)經(jīng)典的鏈表刪除操作來(lái)刪除钾虐。

同樣噪窘,我們需要定義一個(gè)findPrev函數(shù)來(lái)找到前一個(gè)數(shù)據(jù)。

   function findPrev(item) {
    var currNode = this.head;
    while (!(currNode.next == null) && (currNode.next.data != item)) {
        currNode = currNode.next;
    }
    return currNode;
}

這里的遍歷類(lèi)似于find的遍歷效扫,只是通過(guò)”next“,讓當(dāng)前的數(shù)據(jù)提前了一位倔监。

顯示功能

最后我們還需要一個(gè)display()函數(shù)來(lái)顯示我們的操作

 function display() {
    var currNode = this.head;
    while (!(currNode == null)) {
        console.log(currNode.data);
        currNode = currNode.next; } }

Node.js編譯JS

JS的編譯有很多種,但這里我們打算用傳統(tǒng)的Node.js 下載地址

  1. 下載完之后菌仁,我們要用電腦自帶的命令行提示符來(lái)進(jìn)行操作
  2. 打開(kāi)命令行提示符之后浩习,我們先檢查是否成功安裝了Node.js
    輸入命令:node -v 回車(chē)


如果出現(xiàn)了上圖的指示,就說(shuō)明成功了济丘。v10.15.3是我的電腦安裝的版本

  1. 通過(guò)"cd" 指令一步步找到你的 js 文件所在的文件夾


  2. 輸入 node + "js文件名" 進(jìn)行編譯

編譯結(jié)果
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末谱秽,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子摹迷,更是在濱河造成了極大的恐慌疟赊,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,122評(píng)論 6 505
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件峡碉,死亡現(xiàn)場(chǎng)離奇詭異近哟,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)异赫,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,070評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門(mén)椅挣,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)头岔,“玉大人,你說(shuō)我怎么就攤上這事鼠证∠靠ⅲ” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 164,491評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵量九,是天一觀的道長(zhǎng)适掰。 經(jīng)常有香客問(wèn)我,道長(zhǎng)荠列,這世上最難降的妖魔是什么类浪? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,636評(píng)論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮肌似,結(jié)果婚禮上费就,老公的妹妹穿的比我還像新娘。我一直安慰自己川队,他們只是感情好力细,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,676評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著固额,像睡著了一般眠蚂。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上斗躏,一...
    開(kāi)封第一講書(shū)人閱讀 51,541評(píng)論 1 305
  • 那天逝慧,我揣著相機(jī)與錄音,去河邊找鬼啄糙。 笑死笛臣,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的隧饼。 我是一名探鬼主播捐祠,決...
    沈念sama閱讀 40,292評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼桑李!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起窿给,我...
    開(kāi)封第一講書(shū)人閱讀 39,211評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤贵白,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后崩泡,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體禁荒,經(jīng)...
    沈念sama閱讀 45,655評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,846評(píng)論 3 336
  • 正文 我和宋清朗相戀三年角撞,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了呛伴。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片勃痴。...
    茶點(diǎn)故事閱讀 39,965評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖热康,靈堂內(nèi)的尸體忽然破棺而出沛申,到底是詐尸還是另有隱情,我是刑警寧澤姐军,帶...
    沈念sama閱讀 35,684評(píng)論 5 347
  • 正文 年R本政府宣布铁材,位于F島的核電站,受9級(jí)特大地震影響奕锌,放射性物質(zhì)發(fā)生泄漏著觉。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,295評(píng)論 3 329
  • 文/蒙蒙 一惊暴、第九天 我趴在偏房一處隱蔽的房頂上張望饼丘。 院中可真熱鬧,春花似錦辽话、人聲如沸肄鸽。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,894評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)贴捡。三九已至,卻和暖如春村砂,著一層夾襖步出監(jiān)牢的瞬間烂斋,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,012評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工础废, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留汛骂,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,126評(píng)論 3 370
  • 正文 我出身青樓评腺,卻偏偏與公主長(zhǎng)得像帘瞭,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子蒿讥,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,914評(píng)論 2 355

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