日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 前端技术 > javascript >内容正文

javascript

java合并两个有序链表_JS实现的合并两个有序链表算法示例

發布時間:2023/12/2 javascript 26 豆豆
生活随笔 收集整理的這篇文章主要介紹了 java合并两个有序链表_JS实现的合并两个有序链表算法示例 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

本文實例講述了JS實現的合并兩個有序鏈表算法。分享給大家供大家參考,具體如下:

將兩個有序鏈表合并為一個新的有序鏈表并返回。新鏈表是通過拼接給定的兩個鏈表的所有節點組成的。

示例:

輸入:1->2->4, 1->3->4

輸出:1->1->2->3->4->4

可以直接運行的方案:

function Node(element) {

this.element = element;//當前節點的元素

this.next = null;//下一個節點鏈接

}

function List() {

this.head = new Node("head");//頭節點

this.find = find;//查找節點

this.insert = insert;//插入節點

this.remove = remove;//刪除節點

this.display = display;//顯示鏈表

this.findPrevious = findPrevious; //查找前一個節點

}

//下面的函數是操作方法:對應List類構造函數中的名稱

//查找給定節點

function find(item) {

var currNode = this.head;

while(currNode.element != item) {

currNode = currNode.next;

}

return currNode;

}

//向鏈表插入一個節點

function insert(newElement,item) {

var newNode = new Node(newElement);

var current = this.find(item);

if(current == null)

return console.log("can't find the item");

newNode.next = current.next;

current.next = newNode;

}

//刪除節點

function remove(item) {

var prevNode = this.findPrevious(item);

if(prevNode.next != null)

prevNode.next = prevNode.next.next;

}

//從鏈表中刪除節點時,我們先要找個待刪除節點的前一個節點,找到后,我們修改它的 next 屬性,使其不在指向待刪除的節點,而是待刪除節點的下一個節點。那么,我們就得需要定義一個 findPrevious 方法遍歷鏈表,檢查每一個節點的下一個節點是否存儲待刪除的數據。如果找到,返回該節點,這樣就可以修改它的 next 屬性了。

//查找帶刪除節點的前一個節點

function findPrevious(item) {

var currNode = this.head;

while(currNode.next != null && currNode.next.element != item) {

currNode = currNode.next;

}

return currNode;

}

//顯示鏈表元素

function display() {

var current = this.head;

while(current.next != null) {

console.log(current.next.element);

current = current.next;

}

}

/**

* @param {Node} l1

* @param {Node} l2

* @return {Node}

*/

var mergeTwoLists = function(l1, l2) {

// 模仿鏈表的數據結構

var mergedHead = { element : -1, next : null },

cur = mergedHead;

while (l1 && l2){

if(l1.element <= l2.element){

cur.next = l1;

l1 = l1.next;

}

else {

cur.next = l2;

l2 = l2.next;

}

cur = cur.next;

}

cur.next = l1 || l2

return mergedHead.next;

};

let list1 = new List();

list1.insert(1,'head');

list1.insert(2,1);

list1.insert(4,2);

console.log(list1.display());

let list2 = new List();

list2.insert(1,'head');

list2.insert(3,1);

list2.insert(4,3);

console.log(list2.display());

console.log(mergeTwoLists(list1.head,list2.head))

感興趣的朋友可以使用在線HTML/CSS/JavaScript代碼運行工具:http://tools.jb51.net/code/HtmlJsRun測試上述代碼,查看運行效果。

希望本文所述對大家JavaScript程序設計有所幫助。

總結

以上是生活随笔為你收集整理的java合并两个有序链表_JS实现的合并两个有序链表算法示例的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。