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 相关文章推荐
JavaScript中清空数组的三种方法分享
Apr 07 Javascript
Javascript selection的兼容性写法介绍
Dec 20 Javascript
Node.js编码规范
Jul 14 Javascript
JS实现的倒计时效果实例(2则实例)
Dec 23 Javascript
基于jquery实现图片相关操作(重绘、获取尺寸、调整大小、缩放)
Dec 25 Javascript
Jquery attr()方法 属性赋值和属性获取详解
Apr 15 Javascript
解决vue-router在同一个路由下切换,取不到变化的路由参数问题
Sep 01 Javascript
jquery3和layui冲突导致使用layui.layer.full弹出全屏iframe窗口时高度152px问题
May 12 jQuery
layui 实现表格某一列显示图标
Sep 19 Javascript
jQuery 图片查看器插件 Viewer.js用法简单示例
Apr 04 jQuery
浅谈js数组splice删除某个元素爬坑
Oct 14 Javascript
vue使用v-model进行跨组件绑定的基本实现方法
Apr 28 Vue.js
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
基于PHPexecl类生成复杂的报表表头示例
2016/10/14 PHP
Smarty日期时间操作方法示例
2016/11/15 PHP
PHPCrawl爬虫库实现抓取酷狗歌单的方法示例
2017/12/21 PHP
Laravel 自定命令以及生成文件的例子
2019/10/23 PHP
tp5.1 框架数据库高级查询技巧实例总结
2020/05/25 PHP
JavaScript 变量命名规则
2009/09/23 Javascript
初识javascript 文档碎片
2010/07/13 Javascript
jQuery 源码分析笔记(3) Deferred机制
2011/06/19 Javascript
利用json获取字符出现次数的代码
2012/03/22 Javascript
JavaScript对象学习经验整理
2013/10/12 Javascript
简单选项卡 js和jquery制作方法分享
2014/02/26 Javascript
javascript生成随机颜色示例代码
2014/05/05 Javascript
JavaScript代码性能优化总结篇
2016/05/15 Javascript
JavaScript编程中实现对象封装特性的实例讲解
2016/06/24 Javascript
tablesorter.js表格排序使用方法(支持中文排序)
2017/02/10 Javascript
Angularjs的启动过程分析
2017/07/18 Javascript
webpack 2.x配置reactjs基本开发环境详解
2017/08/08 Javascript
使用Fullpage插件快速开发整屏翻页的页面
2017/09/13 Javascript
javascript标准库(js的标准内置对象)总结
2018/05/26 Javascript
webpack打包react项目的实现方法
2018/06/21 Javascript
通过js示例讲解时间复杂度与空间复杂度
2019/08/06 Javascript
js实现淘宝首页的banner栏效果
2019/11/26 Javascript
使用Vant完成通知栏Notify的提示操作
2020/11/11 Javascript
使用Python的Flask框架表单插件Flask-WTF实现Web登录验证
2016/07/12 Python
Python3 socket同步通信简单示例
2017/06/07 Python
python机器学习之神经网络(三)
2017/12/20 Python
selenium+python自动化测试之页面元素定位
2019/01/23 Python
美国网上花店:JustFlowers
2017/02/12 全球购物
Blank NYC官网:夹克、牛仔裤等
2020/12/16 全球购物
武汉英思工程科技有限公司&ndash;ORACLE面试测试题目
2012/04/30 面试题
《翻越远方的大山》教学反思
2014/04/13 职场文书
博士生专家推荐信
2014/09/26 职场文书
员工自我评价范文
2015/03/11 职场文书
2015年司机工作总结
2015/04/23 职场文书
Python编写可视化界面的全过程(Python+PyCharm+PyQt)
2021/05/17 Python
Python 批量下载阴阳师网站壁纸
2021/05/19 Python