JS实现的合并两个有序链表算法示例
网络编程 2021-07-04 15:50www.168986.cn编程入门
这篇文章主要介绍了JS实现的合并两个有序链表算法,结合实例形式分析了JavaScript链表的定义、节点插入、删除、查找等相关算法实现技巧,需要的朋友可以参考下
本文实例讲述了JS实现的合并两个有序链表算法。分享给大家供大家参考,具体如下
将两个有序链表合并为一个新的有序链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的。
示例
输入1->2->4, 1->3->4
输出1->1->2->3->4->4
可以直接运行的方案
<script> 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; //查找前一个节点 } //狼蚁网站SEO优化的函数是操作方法对应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)) </script>
感兴趣的朋友可以使用在线HTML/CSS/JavaScript代码运行工具测试上述代码,查看运行效果。
更多关于JavaScript相关内容感兴趣的读者可查看本站专题《》、《》、《》、《》、《》、《》及《》
希望本文所述对大家JavaScript程序设计有所帮助。
上一篇:JS实现电话号码的字母组合算法示例
下一篇:JS实现判断有效的数独算法示例
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程