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

本文实例讲述了JS实现的合并两个有序链表算法。分享给大家供大家参考,具体如下:

将两个有序链表合并为一个新的有序链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的。

示例:

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

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

576fcf0935fa2ace3aa551d6f8bc299b.png

可以直接运行的方案:

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程序设计有所帮助。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值