国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

javascript數(shù)據(jù)結(jié)構(gòu)之雙鏈表插入排序?qū)嵗斀?/h1>
2019-11-20 11:09:51
字體:
供稿:網(wǎng)友

本文實例講述了javascript數(shù)據(jù)結(jié)構(gòu)之雙鏈表插入排序?qū)崿F(xiàn)方法。分享給大家供大家參考,具體如下:

數(shù)組存儲前提下,插入排序算法,在最壞情況下,前面的元素需要不斷向后移,以便在插入點留出空位,讓目標元素插入。

換成鏈表時,顯然無需做這種大量移動,根據(jù)每個節(jié)點的前驅(qū)節(jié)點“指針”,向前找到插入點后,直接把目標值從原鏈表上摘下,然后在插入點把鏈表斷成二截,然后跟目標點重新接起來即可。

<!doctype html><html><head>  <title>雙鏈表-插入排序</title>  <meta http-equiv="Content-Type" content="text/html; charset=gb2312" /></head><script type="text/javascript">  //節(jié)點類  var Node = function (pData) {    this.next = null; //后繼“指針”    this.prev = null; //前驅(qū)"指針"    this.data = pData;  }  //單鏈表(約定:頭節(jié)點不放內(nèi)容,當哨兵位,有效元素從頭節(jié)點后的第1個元素開始)  var DbLinkList = function () {    this.head = new Node(null); //頭節(jié)點       //插入新元素    this.insert = function (pNodeValue) {      var newNode = new Node(pNodeValue);      //如果只有頭節(jié)點      if (this.head.next == null) {        this.head.next = newNode;        newNode.prev = this.head;        return;      }      //否則遍歷找到尾節(jié)點      var p = this.head;      while (p.next != null) {        p = p.next;      }      p.next = newNode;      newNode.prev = p;    }    //獲取第n個元素的數(shù)據(jù)值    this.getData = function (index) {      if (index < 1 || index > this.size) {        return null;      }      var p = this.head;      var i = 1;      while (p.next != null && i <= index) {        p = p.next;        i += 1;      }      return p.data;    }    //取尾節(jié)點    this.getTail = function () {      if (this.head.next == null) {        return null;      }      var p = this.head.next;      while (p.next != null) {        p = p.next;      }      return p;    }    //刪除指定位置的元素    this.removeAt = function (index) {      if (index < 1 || index > this.size) {        return null;      }      var p = this.head;      var i = 1;      //從頭開始遍歷,找到index位置的前一個元素      while (p.next != null && i < index) {        p = p.next;        i += 1;      }      p.next = p.next.next; //修改index位置前一個元素的后繼指針      p.next.prev = p;      return p.data; //返回刪除元素的值        }    //打印所有元素    this.print = function () {      document.write("<br/>");      if (this.head.next == null) {        return;      }      var p = this.head.next;      while (p.next != null) {        document.write(p.data + " ");        p = p.next;      }      document.write(p.data + " "); //最后一個元素,需要單獨打印      document.write("<br/>");    }    //從后打印所有元素    this.printFromBack = function () {      document.write("該鏈表共有" + this.size + "個元素,從后向前分別為:<br/>");      var tail = this.getTail();      var p = tail;      if (p == null) {        return;      }      while (p.prev != null) {        document.write(p.data + " ");        p = p.prev;      }      document.write("<br/>");    }    //插入排序    this.insertSort = function () {      if (this.head.next == null || this.head.next.next == null) {        return;      }      var p = this.head.next;      while (true) {        if (p == null) {          return;        }        var t = p.prev;        //向前查找p之前的插入點        while (t.prev != null && t.data > p.data) {          t = t.prev;        }        //如果插入點就是p的前驅(qū)節(jié)點,不用調(diào)整,        //忽略,直接進入下一輪        if (t.next == p) {          p = p.next;          continue;        }        //將p的后續(xù)節(jié)點先保護起來,以便下一輪循環(huán)時確定起始位置        var x = p.next;        //將p從鏈表上摘下        if (p.next != null) {          p.next.prev = p.prev;        }        p.prev.next = p.next;        //p插入到t之后        t.next.prev = p;        p.next = t.next;        t.next = p;        p.prev = t;        this.print(); //打印輸出,調(diào)試用          //重新將p定位到下一輪循環(huán)的"正確"起始節(jié)點        p = x;      }    }  }  var linkTest = new DbLinkList();  linkTest.insert(10);  linkTest.insert(9);  linkTest.insert(8);  linkTest.insert(7);  linkTest.insert(6);  linkTest.insert(5);  linkTest.insert(4);  linkTest.insert(3);  linkTest.insert(2);  linkTest.insert(1);  document.write("--排序前---<br/>")  linkTest.print();  linkTest.insertSort();  document.write("<br/>--排序后---<br/>")  linkTest.print();</script></html>

運行結(jié)果如下:

 --排序前---10 9 8 7 6 5 4 3 2 1 9 10 8 7 6 5 4 3 2 1 8 9 10 7 6 5 4 3 2 1 7 8 9 10 6 5 4 3 2 1 6 7 8 9 10 5 4 3 2 1 5 6 7 8 9 10 4 3 2 1 4 5 6 7 8 9 10 3 2 1 3 4 5 6 7 8 9 10 2 1 2 3 4 5 6 7 8 9 10 1 1 2 3 4 5 6 7 8 9 10 --排序后---1 2 3 4 5 6 7 8 9 10

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

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表

主站蜘蛛池模板: 金沙县| 尼木县| 新郑市| 高淳县| 巍山| 平昌县| 靖边县| 商都县| 龙胜| 南丹县| 纳雍县| 龙胜| 静乐县| 耿马| 泰安市| 景泰县| 平远县| 淮南市| 志丹县| 石城县| 普定县| 浦县| 台北县| 双城市| 通化县| 古蔺县| 全椒县| 黑河市| 六安市| 察雅县| 闽清县| 江安县| 那坡县| 黄浦区| 磐安县| 海兴县| 翼城县| 怀远县| 洛隆县| 浙江省| 江山市|