雙連結串列插入排序例項程式碼
本章節分享一段程式碼例項,它實現了雙連結串列插入排序功能。
需要的朋友可以做一下參考,在程式碼之後會有簡單的介紹,程式碼例項如下:
[HTML] 純文字檢視 複製程式碼<!doctype html> <html> <head> <meta charset=" utf-8"> <meta name="author" content="http://www.softwhy.com/" /> <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> </head> <body> </body> </html>
陣列儲存前提下,插入排序演算法,在最壞情況下,前面的元素需要不斷向後移,以便在插入點留出空位,讓目標元素插入。
換成連結串列時,顯然無需做這種大量移動,根據每個節點的前驅節點“指標”,向前找到插入點後,直接把目標值從原連結串列上摘下,然後在插入點把連結串列斷成二截,然後跟目標點重新接起來即可。
相關文章
- 單雙連結串列
- 基本資料結構實現--雙連結串列【含測試程式碼】資料結構
- 資料結構-單連結串列、雙連結串列資料結構
- 4-雙連結串列的操作
- 【資料結構】雙連結串列(c++)資料結構C++
- 圖解雙連結串列(Java實現)圖解Java
- 連結串列-插入排序排序
- Linux核心之資料雙連結串列Linux
- 迴圈雙連結串列的簡單操作
- 深入理解Redis 資料結構—雙連結串列Redis資料結構
- js在Node.js下實現單連結串列與雙連結串列結構Node.js
- 019 通過連結串列學Rust之雙連結串列實現PeekRust
- 019 透過連結串列學Rust之雙連結串列實現PeekRust
- 陣列模擬雙連結串列,你get到了嗎?陣列
- 實戰PHP資料結構基礎之雙連結串列PHP資料結構
- 資料結構思維 第五章 雙連結串列資料結構
- 016 通過連結串列學習Rust之安全的雙連結串列佈局Rust
- 016 透過連結串列學習Rust之安全的雙連結串列佈局Rust
- 點選連結不跳轉例項程式碼
- js動態連結<a>元素程式碼例項JS
- 看得見的資料結構Android版之雙連結串列篇資料結構Android
- jQuery is() 程式碼例項jQuery
- PE結構-合併節(附例項程式碼)
- JDK 7 新特性小結(包含例項程式碼)JDK
- js模擬點選連結程式碼例項JS
- 去掉連結a的虛線框程式碼例項
- jQuery選項卡例項程式碼jQuery
- dom操作程式碼例項
- javascript的for in例項程式碼JavaScript
- drag拖拽程式碼例項
- requestAnimationFrame()動畫例項程式碼requestAnimationFrame動畫
- $$和||使用程式碼例項
- js刮刮樂程式碼例項JS
- canvas刮刮樂程式碼例項Canvas
- css梯形程式碼例項CSS
- toJSON()程式碼例項JSON
- [轉]BDB例項程式碼
- IOS程式碼例項區iOS