亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

javascript數據結構之雙鏈表插入排序實例詳解

2019-11-20 11:09:51
字體:
來源:轉載
供稿:網友

本文實例講述了javascript數據結構之雙鏈表插入排序實現方法。分享給大家供大家參考,具體如下:

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

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

<!doctype html><html><head>  <title>雙鏈表-插入排序</title>  <meta http-equiv="Content-Type" content="text/html; charset=gb2312" /></head><script type="text/javascript">  //節點類  var Node = function (pData) {    this.next = null; //后繼“指針”    this.prev = null; //前驅"指針"    this.data = pData;  }  //單鏈表(約定:頭節點不放內容,當哨兵位,有效元素從頭節點后的第1個元素開始)  var DbLinkList = function () {    this.head = new Node(null); //頭節點       //插入新元素    this.insert = function (pNodeValue) {      var newNode = new Node(pNodeValue);      //如果只有頭節點      if (this.head.next == null) {        this.head.next = newNode;        newNode.prev = this.head;        return;      }      //否則遍歷找到尾節點      var p = this.head;      while (p.next != null) {        p = p.next;      }      p.next = newNode;      newNode.prev = p;    }    //獲取第n個元素的數據值    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;    }    //取尾節點    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的前驅節點,不用調整,        //忽略,直接進入下一輪        if (t.next == p) {          p = p.next;          continue;        }        //將p的后續節點先保護起來,以便下一輪循環時確定起始位置        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(); //打印輸出,調試用          //重新將p定位到下一輪循環的"正確"起始節點        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>

運行結果如下:

 --排序前---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程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
91亚洲精品久久久| 91人成网站www| 狠狠躁夜夜躁人人躁婷婷91| 日韩精品999| 国产精品久久久久久久久久久久久久| 九九久久久久99精品| 91精品国产乱码久久久久久久久| 久久视频在线观看免费| 日韩欧美亚洲综合| 亚洲乱码一区二区| 日韩中文字幕网址| 国产美女被下药99| 欧洲成人免费视频| 这里只有精品丝袜| 日韩欧美在线视频日韩欧美在线视频| 亚洲国产欧美一区二区三区久久| 日韩欧美国产成人| 中文字幕av一区二区| 国产一区二区三区日韩欧美| 日韩在线免费观看视频| 中文字幕亚洲情99在线| 日韩a**站在线观看| www.国产精品一二区| 欧美久久精品午夜青青大伊人| 成人日韩av在线| 日韩电影中文字幕| 久久久久久国产精品美女| 性欧美长视频免费观看不卡| 美女国内精品自产拍在线播放| 国产盗摄xxxx视频xxx69| 成人av在线网址| 亚洲国产精品人久久电影| 欧美大全免费观看电视剧大泉洋| 国产精品精品国产| 欧美国产视频日韩| 亚洲精品suv精品一区二区| 欧美电影免费观看网站| 91高清视频在线免费观看| 国产精品日韩欧美综合| 久久久国产在线视频| 亚洲影影院av| 欧美成人免费va影院高清| 欧美成年人在线观看| 国产精品一区av| 欧美大片免费观看在线观看网站推荐| 97精品视频在线播放| 国产成人亚洲精品| 日韩美女在线播放| www.日韩不卡电影av| 欧美激情一区二区三级高清视频| 欧美一区二三区| 亚洲女成人图区| 高清欧美性猛交xxxx黑人猛交| 日韩精品免费综合视频在线播放| 成人看片人aa| 欧美日韩在线看| 97精品国产97久久久久久春色| 成人免费网站在线| 91精品国产高清久久久久久| 久久久久久久久久国产精品| 日韩视频免费看| 日韩精品视频在线观看网址| 欧美性高潮床叫视频| 久久99精品久久久久久噜噜| 精品人伦一区二区三区蜜桃网站| 日韩中文综合网| 91av视频在线观看| 尤物九九久久国产精品的特点| 久久天堂av综合合色| 国产第一区电影| 91啪国产在线| 97精品一区二区视频在线观看| 欧美性生交xxxxxdddd| 在线观看国产成人av片| 国产91精品久| 欧美精品一区二区三区国产精品| 国产精品丝袜视频| 性欧美视频videos6一9| 91精品视频免费观看| 久99九色视频在线观看| 亚洲国产古装精品网站| 国产精品自拍偷拍| 91精品国产九九九久久久亚洲| 亚洲精品久久久久| 国产日韩在线免费| 亚洲男人天堂2024| 亚洲黄色成人网| 亚洲欧美一区二区激情| 国产精品一香蕉国产线看观看| 欧美大学生性色视频| 亚洲专区中文字幕| 97精品一区二区视频在线观看| 久久久视频免费观看| 九九九热精品免费视频观看网站| 日本久久亚洲电影| 亚洲乱码av中文一区二区| 成人午夜在线影院| 国产一区二区三区在线| 91社区国产高清| 亚洲免费av片| 日本久久久a级免费| 欧美日在线观看| 亚洲第一综合天堂另类专| 国产成人精品优优av| 欧美日韩ab片| 26uuu亚洲伊人春色| 国外日韩电影在线观看| 成人观看高清在线观看免费| 亚洲片在线资源| 日韩有码片在线观看| 欧美日韩中文字幕在线视频| 日韩在线视频网站| 91欧美精品午夜性色福利在线| 久久777国产线看观看精品| 欧美日韩国产一区在线| 青青草99啪国产免费| 欧美视频在线观看免费网址| 亚洲免费电影在线观看| 日韩风俗一区 二区| 亚洲人在线视频| 精品国产一区二区在线| 97人洗澡人人免费公开视频碰碰碰| 国产精品丝袜白浆摸在线| 91精品视频免费| 国产97在线视频| 97久久精品人人澡人人爽缅北| 亚洲a中文字幕| 亚洲精品国产精品国自产观看浪潮| 国产成人一区二| 成人在线视频网站| 国产成+人+综合+亚洲欧美丁香花| 日韩精品免费在线观看| 欧美超级乱淫片喷水| 91探花福利精品国产自产在线| 成人国产精品久久久久久亚洲| 久久影院资源网| 92版电视剧仙鹤神针在线观看| 91久久久久久久久久| 久久精品免费播放| 日日噜噜噜夜夜爽亚洲精品| 亚洲欧美激情一区| 欧美激情精品久久久久久变态| 91精品国产91久久| 亚洲欧美另类自拍| 奇米四色中文综合久久| 精品国产鲁一鲁一区二区张丽| 欧美日韩在线视频观看| 国产97在线播放| 精品欧美国产一区二区三区| 国产精品成人av在线| 欧美色图在线视频| 日韩电影免费观看在线观看| 69久久夜色精品国产69| 欧美激情xxxx| 日韩免费不卡av| 毛片精品免费在线观看| 国产精品一区二区3区| 日韩免费在线免费观看| 91在线视频精品| 日韩久久精品成人| 国色天香2019中文字幕在线观看| 亚洲人成电影网站色xx| 久久久久久久久国产| 欧美丰满少妇xxxxx|