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


Posted in Javascript onFebruary 25, 2019

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

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

示例:

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

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

可以直接运行的方案:

<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; //查找前一个节点
}
//下面的函数是操作方法:对应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代码运行工具:http://tools.3water.com/code/HtmlJsRun测试上述代码,查看运行效果。

希望本文所述对大家JavaScript程序设计有所帮助。

Javascript 相关文章推荐
HTML TO JavaScript 转换
Jun 26 Javascript
怎么引入(调用)一个JS文件
May 26 Javascript
Bootstrap图片轮播组件使用实例解析
Jun 30 Javascript
纯JS焦点图特效实例(可一个页面多用)
Dec 07 Javascript
JS检测数组类型的方法小结
Mar 14 Javascript
Node+Express+MongoDB实现登录注册功能实例
Apr 23 Javascript
浅析Angular2子模块以及异步加载
Apr 24 Javascript
原生js实现简单的模态框示例
Sep 08 Javascript
JavaScript实现修改伪类样式
Nov 27 Javascript
webpack4.x打包过程详解
Jul 18 Javascript
IE8中jQuery.load()加载页面不显示的原因
Nov 15 jQuery
vue2和vue3的v-if与v-for优先级对比学习
Oct 10 Javascript
JS实现判断有效的数独算法示例
Feb 25 #Javascript
js实现通过开始结束控制的计时器
Feb 25 #Javascript
js实现倒计时器自定义时间和暂停
Feb 25 #Javascript
JS module的导出和导入的实现代码
Feb 25 #Javascript
js实现多个倒计时并行 js拼团倒计时
Feb 25 #Javascript
js实现网页同时进行多个倒计时功能
Feb 25 #Javascript
js实现一个页面多个倒计时的3种方法
Feb 25 #Javascript
You might like
杏林同学录(八)
2006/10/09 PHP
Linux下将excel数据导入到mssql数据库中的方法
2010/02/08 PHP
PHP错误Allowed memory size of 67108864 bytes exhausted的3种解决办法
2014/07/28 PHP
Thinkphp+smarty+uploadify实现无刷新上传
2015/07/30 PHP
PHP6新特性分析
2016/03/03 PHP
基于php编程规范(详解)
2017/08/17 PHP
帮助避免错误的Javascript陷阱清单
2009/05/31 Javascript
JavaScript 继承使用分析
2011/05/12 Javascript
js获取时间并实现字符串和时间戳之间的转换
2015/01/05 Javascript
javascript实现列表滚动的方法
2015/07/30 Javascript
JS实现图片高亮展示效果实例
2015/11/24 Javascript
jQuery 1.9.1源码分析系列(十五)之动画处理
2015/12/03 Javascript
理解JavaScript中worker事件api
2015/12/25 Javascript
DWR中各种java方法的调用
2016/05/04 Javascript
获取JavaScript异步函数的返回值
2016/12/21 Javascript
在点击div中的p时,如何阻止事件冒泡
2017/02/07 Javascript
vue事件修饰符和按键修饰符用法总结
2017/07/25 Javascript
JS动态修改网页body的背景色实例代码
2017/10/07 Javascript
vue-router的HTML5 History 模式设置
2018/09/08 Javascript
Vuejs+vue-router打包+Nginx配置的实例
2018/09/20 Javascript
VUE简单的定时器实时刷新的实现方法
2019/01/20 Javascript
详解在Python程序中使用Cookie的教程
2015/04/30 Python
python字符串,数值计算
2016/10/05 Python
基于python中staticmethod和classmethod的区别(详解)
2017/10/24 Python
python skimage 连通性区域检测方法
2018/06/21 Python
django框架单表操作之增删改实例分析
2019/12/16 Python
一个基于canvas的移动端图片编辑器的实现
2020/10/28 HTML / CSS
美国折扣网站:jClub
2017/08/07 全球购物
Zavvi西班牙:电子游戏、极客服装、Blu-ray、Funko Pop等
2019/05/03 全球购物
土耳其玩具商店:Toyzz Shop
2019/08/02 全球购物
办公室秘书自我鉴定
2014/01/18 职场文书
股票投资建议书
2014/05/19 职场文书
董事长秘书岗位职责
2015/02/13 职场文书
道德与公民自我评价
2015/03/09 职场文书
小学英语教学随笔
2015/08/14 职场文书
MySQL分库分表与分区的入门指南
2021/04/22 MySQL