中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

JS實現的合并兩個有序鏈表算法示例

發布時間:2020-10-03 15:09:07 來源:腳本之家 閱讀:353 作者:gqj.cn 欄目:web開發

本文實例講述了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.jb51.net/code/HtmlJsRun測試上述代碼,查看運行效果。

更多關于JavaScript相關內容感興趣的讀者可查看本站專題:《JavaScript數學運算用法總結》、《JavaScript數據結構與算法技巧總結》、《JavaScript數組操作技巧總結》、《JavaScript排序算法總結》、《JavaScript遍歷算法與技巧總結》、《JavaScript查找算法技巧總結》及《JavaScript錯誤與調試技巧總結》

希望本文所述對大家JavaScript程序設計有所幫助。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

繁昌县| 岳普湖县| 剑川县| 略阳县| 靖安县| 襄樊市| 广昌县| 三亚市| 漳平市| 汉阴县| 渝北区| 宾阳县| 民县| 怀宁县| 巴林左旗| 陈巴尔虎旗| 孙吴县| 西贡区| 固原市| 阿合奇县| 固安县| 铁岭市| 昌平区| 右玉县| 南涧| 渭南市| 湖北省| 抚顺县| 山阳县| 揭东县| 平南县| 平乡县| 雷山县| 大城县| 巫山县| 左权县| 顺昌县| 临桂县| 湟源县| 准格尔旗| 广东省|