最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

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

来源:动视网 责编:小采 时间:2020-11-27 22:00:40
文档

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

JS实现的合并两个有序链表算法示例:本文实例讲述了JS实现的合并两个有序链表算法。分享给大家供大家参考,具体如下: 将两个有序链表合并为一个新的有序链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的。 示例: 输入:1->2->4, 1->3->4 输出:1->1-
推荐度:
导读JS实现的合并两个有序链表算法示例:本文实例讲述了JS实现的合并两个有序链表算法。分享给大家供大家参考,具体如下: 将两个有序链表合并为一个新的有序链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的。 示例: 输入:1->2->4, 1->3->4 输出:1->1-


可以直接运行的方案:

<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.jb51.net/code/HtmlJsRun测试上述代码,查看运行效果。

更多关于JavaScript相关内容感兴趣的读者可查看本站专题:《JavaScript数学运算用法总结》、《JavaScript数据结构与算法技巧总结》、《JavaScript数组操作技巧总结》、《JavaScript排序算法总结》、《JavaScript遍历算法与技巧总结》、《JavaScript查找算法技巧总结》及《JavaScript错误与调试技巧总结》

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

文档

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

JS实现的合并两个有序链表算法示例:本文实例讲述了JS实现的合并两个有序链表算法。分享给大家供大家参考,具体如下: 将两个有序链表合并为一个新的有序链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的。 示例: 输入:1->2->4, 1->3->4 输出:1->1-
推荐度:
标签: 示例 实例 的两个
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top