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

首頁 > 編程 > JavaScript > 正文

JavaScript數據結構與算法之基本排序算法定義與效率比較【冒泡、選擇、插入排序】

2019-11-19 12:05:12
字體:
來源:轉載
供稿:網友

本文實例講述了JavaScript數據結構與算法之基本排序算法定義與效率比較。分享給大家供大家參考,具體如下:

javascript數據結構與算法--基本排序算法(冒泡、選擇、排序)及效率比較

一、數組測試平臺

javascript數據結構與算法--基本排序(封裝基本數組的操作),封裝常規數組操作的函數,比如:插入新數據,顯示數組數據,還有交換數組元素等操作來調用不同的排序算法

function CArray(numElements) {  this.dataStore = [];  this.pos = 0;//是一個索引值,默認為0,從第一個開始  this.numElements = numElements;//是保存所有的數組元素  this.insert = insert;//向數組中插入一個元素的方法  this.toString = toString;//顯示數組中所有元素  this.clear = clear;//清空數組數據  this.setData = setData;//生成了存儲在數組中的隨機數字  this.swap = swap;//交換數組中兩個元素的位置  this.bubbleSort = bubbleSort;  /*將傳入的數組,存儲在datastore中*/  for (var i = 0; i < numElements.length; ++i) {    this.dataStore[i] = numElements[i];  }}function setData() {  for (var i = 0; i < this.numElements; ++i) {    this.dataStore[i] = Math.floor(Math.random() *      (this.numElements+1));  }}function clear() {  for (var i = 0; i < this.dataStore.length; ++i) {    this.dataStore[i] = 0;  }}function insert(element) {  this.dataStore[this.pos++] = element;}function toString() {  var retstr = "";  for (var i = 0; i < this.dataStore.length; ++i) {    retstr += this.dataStore[i] + " ";    if (i > 0 && i % 10 == 0) {      retstr += "/n";    }  }  return retstr;}function swap(arr, index1, index2) {  var temp = arr[index1];  arr[index1] = arr[index2];  arr[index2] = temp;}//測試生成一組數組數據(隨機數)var numElements = 100;var myNums = new CArray(numElements);myNums.setData();console.log(myNums.toString());

17 94 81 80 25 24 73 76 24 35 81
63 81 59 4 76 30 47 73 98 18
54 36 53 47 22 60 88 41 66 24
73 94 40 45 72 74 14 61 92 48
36 12 42 11 12 82 24 84 60 1
17 98 63 36 84 13 18 50 89 26
98 1 6 54 52 69 6 52 98 14
79 28 19 69 76 99 97 100 10 7
24 54 81 73 18 21 45 73 66 30
28 56 54 21 88 31 20 86 48

二、冒泡排序算法

我們先來了解一下冒泡排序算法,它是最慢的排序算法之一,但也是一種最容易實現的排序算法。

之所以叫冒泡排序是因為使用這種排序算法排序時,數據值會像氣泡一樣從數組的一端漂浮到另一端。

假設正在將一組數字按照升序排列,較大的值會浮動到數組的右側,而較小的值則會浮動到數組的左側。

之所以會產生這種現象是因為算法會多次在數組中移動,比較相鄰的數據,當左側值大于右側值時將它們進行互換。

JS代碼如下:

function CArray(numElements) {  this.dataStore = [];  this.pos = 0;//是一個索引值,默認為0,從第一個開始  this.numElements = numElements;//是保存所有的數組元素  this.insert = insert;//向數組中插入一個元素的方法  this.toString = toString;//顯示數組中所有元素  this.clear = clear;//清空數組數據  this.setData = setData;//生成了存儲在數組中的隨機數字  this.swap = swap;//交換數組中兩個元素的位置  this.bubbleSort = bubbleSort;//冒泡算法  /*將傳入的數組,存儲在datastore中*/  for (var i = 0; i < numElements.length; ++i) {    this.dataStore[i] = numElements[i];  }}function setData() {  for (var i = 0; i < this.numElements; ++i) {    this.dataStore[i] = Math.floor(Math.random() *      (this.numElements+1));  }}function clear() {  for (var i = 0; i < this.dataStore.length; ++i) {    this.dataStore[i] = 0;  }}function insert(element) {  this.dataStore[this.pos++] = element;}function toString() {  var retstr = "";  for (var i = 0; i < this.dataStore.length; ++i) {    retstr += this.dataStore[i] + " ";    if (i > 0 && i % 10 == 0) {      retstr += "/n";    }  }  return retstr;}function swap(arr, index1, index2) {  var temp = arr[index1];  arr[index1] = arr[index2];  arr[index2] = temp;}function bubbleSort() {  var numElements = this.dataStore.length;  for (var outer = numElements; outer >= 2; --outer) {    for (var inner = 0; inner <= outer-1; ++inner) {      if (this.dataStore[inner] > this.dataStore[inner+1]) {        swap(this.dataStore, inner, inner+1);      }    }    console.log("outer為" + outer + ": " + this.toString());  }}//測試冒泡排序算法var numElements = [2,4,1,3];var myNums = new CArray(numElements);console.log("原來的數組:"+myNums.toString());myNums.bubbleSort();console.log("排序后的數組:"+myNums.toString());

冒泡算法代碼分析如下:

原先數組為 [2,4,1,3];

1. outer為4的時候

    1. inner為0,值為2,inner+1為1,值為4,不符合,不交換。
    2. inner為1,值為4,inner+1為2,值為1,交換,數組變為[2,1,4,3]
    3. inner為2,值為4,inner+1為3,值為3,交換 數組變為[2,1,3,4]
    4. inner為3,值為4,inner+1為4,不符合 不交換。

2. outer為3的時候

    1. inner為0,值為2,inner+1為1,值為1,交換 數組變為[1,2,3,4]
    2. inner為1, 值為2,inner+1為2,值為3 不符合 不交換。
    3. inner為2, 值為3,inner+1為3,值為4,不符合 不交換。

再下面繼續循環都不符合條件,所以如上就是最后一步了。這就是冒泡排序。

三、選擇排序算法

選擇排序從數組的開頭開始,將第一個元素和其他元素進行比較。

檢查完所有元素后,最小的元素會被放到數組的第一個位置,然后算法會從第二個位置繼續。

這個過程一直進行,當進行到數組的倒數第二個位置時,所有的數據便完成了排序。
選擇排序會用到嵌套循環。

外循環從數組的第一個元素移動到倒數第二個元素;

內循環從第二個數組元素移動到最后一個元素,查找比當前外循環所指向的元素小的元素。

每次內循環迭代后,數組中最小的值都會被賦值到合適的位置。

JS代碼如下:

function CArray(numElements) {  this.dataStore = [];  this.pos = 0;//是一個索引值,默認為0,從第一個開始  this.numElements = numElements;//是保存所有的數組元素  this.insert = insert;//向數組中插入一個元素的方法  this.toString = toString;//顯示數組中所有元素  this.clear = clear;//清空數組數據  this.setData = setData;//生成了存儲在數組中的隨機數字  this.swap = swap;//交換數組中兩個元素的位置  this.selectionSort = selectionSort;//選擇排序算法  /*將傳入的數組,存儲在datastore中*/  for (var i = 0; i < numElements.length; ++i) {    this.dataStore[i] = numElements[i];  }}function setData() {  for (var i = 0; i < this.numElements; ++i) {    this.dataStore[i] = Math.floor(Math.random() *      (this.numElements+1));  }}function clear() {  for (var i = 0; i < this.dataStore.length; ++i) {    this.dataStore[i] = 0;  }}function insert(element) {  this.dataStore[this.pos++] = element;}function toString() {  var retstr = "";  for (var i = 0; i < this.dataStore.length; ++i) {    retstr += this.dataStore[i] + " ";    if (i > 0 && i % 10 == 0) {      retstr += "/n";    }  }  return retstr;}function swap(arr, index1, index2) {  var temp = arr[index1];  arr[index1] = arr[index2];  arr[index2] = temp;}function selectionSort() {  var min, temp;  for (var outer = 0; outer <= this.dataStore.length-2; ++outer) {    min = outer;    for (var inner = outer + 1;inner <= this.dataStore.length-1; ++inner) {      if (this.dataStore[inner] < this.dataStore[min]) {        min = inner;      }    }    swap(this.dataStore, outer, min);    console.log("第"+outer +"次:"+myNums.toString());  }}//測試排序算法var numElements = [2,4,1,3];var myNums = new CArray(numElements);console.log("原來的數組:"+myNums.toString());myNums.selectionSort();console.log("排序后的數組:"+myNums.toString());

原來的數組:2 4 1 3
第0次:1 4 2 3
第1次:1 2 4 3
第2次:1 2 3 4
排序后的數組:1 2 3 4

四、插入排序算法

插入排序有兩個循環。

外循環將數組元素挨個移動,而內循環則對外循環中選中的元素及它前面的那個元素進行比較。

如果外循環中選中的元素比內循環中選中的元素小,那么數組元素會向右移動,為外循環中的這個元素騰出位置

function CArray(numElements) {  this.dataStore = [];  this.pos = 0;//是一個索引值,默認為0,從第一個開始  this.numElements = numElements;//是保存所有的數組元素  this.insert = insert;//向數組中插入一個元素的方法  this.toString = toString;//顯示數組中所有元素  this.clear = clear;//清空數組數據  this.setData = setData;//生成了存儲在數組中的隨機數字  this.swap = swap;//交換數組中兩個元素的位置  this.insertionSort = insertionSort;//插入排序算法  /*將傳入的數組,存儲在datastore中*/  for (var i = 0; i < numElements.length; ++i) {    this.dataStore[i] = numElements[i];  }}function setData() {  for (var i = 0; i < this.numElements; ++i) {    this.dataStore[i] = Math.floor(Math.random() *      (this.numElements+1));  }}function clear() {  for (var i = 0; i < this.dataStore.length; ++i) {    this.dataStore[i] = 0;  }}function insert(element) {  this.dataStore[this.pos++] = element;}function toString() {  var retstr = "";  for (var i = 0; i < this.dataStore.length; ++i) {    retstr += this.dataStore[i] + " ";    if (i > 0 && i % 10 == 0) {      retstr += "/n";    }  }  return retstr;}function swap(arr, index1, index2) {  var temp = arr[index1];  arr[index1] = arr[index2];  arr[index2] = temp;}function insertionSort() {  var temp, inner;  //外循環將數組元素挨個移動  for (var outer = 1; outer <= this.dataStore.length-1; ++outer) {    temp = this.dataStore[outer];//外循環選中的元素temp    inner = outer;    //內循環對外循環中選中的元素temp與temp前面的元素一個個進行比較。    //如果外循環中選中的元素temp比內循環中選中的元素小,那么數組元素會向右移動,為外循環中的這個元素騰出位置    while (inner > 0 && (this.dataStore[inner-1] >= temp)) {      this.dataStore[inner] = this.dataStore[inner-1];      --inner;    }    this.dataStore[inner] = temp;    console.log("第"+outer+"次:"+myNums.toString());  }}//測試排序算法var numElements = [9,1,8,6,2,3,5,4];var myNums = new CArray(numElements);console.log("原來的數組:"+myNums.toString());myNums.insertionSort();console.log("排序后的數組:"+myNums.toString());

原來的數組:9 1 8 6 2 3 5 4 //先用1和1前面的對比,9比1大,所以9向右移動一個位置,給1騰位置
      第1次:1 9 8 6 2 3 5 4 //用8與8前面的對比,9比8大,所以9向右移動一個位置,給8騰位置
      第2次:1 8 9 6 2 3 5 4 //用6與6前面的對比,8,9比6大,所以8、9向右移動一個位置,給6騰位置
      第3次:1 6 8 9 2 3 5 4
      第4次:1 2 6 8 9 3 5 4
      第5次:1 2 3 6 8 9 5 4
      第6次:1 2 3 5 6 8 9 4
      第7次:1 2 3 4 5 6 8 9
排序后的數組:1 2 3 4 5 6 8 9

五、基本排序算法的效率比較

function CArray(numElements) {  this.dataStore = [];  this.pos = 0;//是一個索引值,默認為0,從第一個開始  this.numElements = numElements;//是保存所有的數組元素  this.insert = insert;//向數組中插入一個元素的方法  this.toString = toString;//顯示數組中所有元素  this.clear = clear;//清空數組數據  this.setData = setData;//生成了存儲在數組中的隨機數字  this.swap = swap;//交換數組中兩個元素的位置  this.bubbleSort = bubbleSort;//冒泡排序算法  this.selectionSort = selectionSort;//選擇排序算法  this.insertionSort = insertionSort;//插入排序算法  /*將傳入的數組,存儲在datastore中*/  for (var i = 0; i < numElements.length; ++i) {    this.dataStore[i] = numElements[i];  }}function setData() {  for (var i = 0; i < this.numElements; ++i) {    this.dataStore[i] = Math.floor(Math.random() *      (this.numElements+1));  }}function clear() {  for (var i = 0; i < this.dataStore.length; ++i) {    this.dataStore[i] = 0;  }}function insert(element) {  this.dataStore[this.pos++] = element;}function toString() {  var retstr = "";  for (var i = 0; i < this.dataStore.length; ++i) {    retstr += this.dataStore[i] + " ";    if (i > 0 && i % 10 == 0) {      retstr += "/n";    }  }  return retstr;}function swap(arr, index1, index2) {  var temp = arr[index1];  arr[index1] = arr[index2];  arr[index2] = temp;}function bubbleSort() {  var numElements = this.dataStore.length;  for (var outer = numElements; outer >= 2; --outer) {    for (var inner = 0; inner <= outer-1; ++inner) {      if (this.dataStore[inner] > this.dataStore[inner+1]) {        swap(this.dataStore, inner, inner+1);      }    }//    console.log("outer為" + outer + ": " + this.toString());  }}function selectionSort() {  var min, temp;  for (var outer = 0; outer <= this.dataStore.length-2; ++outer) {    min = outer;    for (var inner = outer + 1;inner <= this.dataStore.length-1; ++inner) {      if (this.dataStore[inner] < this.dataStore[min]) {        min = inner;      }    }    swap(this.dataStore, outer, min);//    console.log("第"+outer +"次:"+this.toString());  }}function insertionSort() {  var temp, inner;  //外循環將數組元素挨個移動  for (var outer = 1; outer <= this.dataStore.length-1; ++outer) {    temp = this.dataStore[outer];//外循環選中的元素    inner = outer;    //內循環則對外循環中選中的元素與它前面的那個元素進行比較。    //如果外循環中選中的元素比內循環中選中的元素小,那么數組元素會向右移動,為外循環中的這個元素騰出位置    while (inner > 0 && (this.dataStore[inner-1] >= temp)) {      this.dataStore[inner] = this.dataStore[inner-1];      --inner;    }    this.dataStore[inner] = temp;//    console.log("第"+outer+"次:"+this.toString());  }}/*測試冒泡、選擇、插入算法的效率*/var numElements = 10000;var nums = new CArray(numElements);nums.setData();var start = new Date().getTime();nums.bubbleSort();var stop = new Date().getTime();var elapsed = stop - start;console.log("用冒泡算法,排序 " + numElements + " 個元素耗時 : " + elapsed + " milliseconds.");start = new Date().getTime();nums.selectionSort();stop = new Date().getTime();elapsed = stop - start;console.log("用選擇算法,排序 " + numElements + " 個元素耗時: " + elapsed + " milliseconds.");start = new Date().getTime();nums.insertionSort();stop = new Date().getTime();elapsed = stop - start;console.log("用插入算法,排序 " + numElements + " 個元素耗時: " + elapsed + " milliseconds.");

運行結果:

選擇排序和插入排序要比冒泡排序快,插入排序是這三種算法中最快的。

感興趣的朋友可以使用在線HTML/CSS/JavaScript代碼運行工具http://tools.VeVB.COm/code/HtmlJsRun測試上述代碼運行效果。

PS:這里再為大家推薦一款關于排序的演示工具供大家參考:

在線動畫演示插入/選擇/冒泡/歸并/希爾/快速排序算法過程工具:
http://tools.VeVB.COm/aideddesign/paixu_ys

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

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
91久久久久久久久久久久久| 国产一区二区丝袜高跟鞋图片| 国产高清视频一区三区| 国产成人avxxxxx在线看| 日韩精品久久久久久久玫瑰园| 欧美一级视频在线观看| 欧美精品制服第一页| 国产精品成人播放| 欧美日韩国产精品一区二区三区四区| 日日骚av一区| 一区二区三区 在线观看视| 中文字幕亚洲欧美在线| 欧美性xxxx极品hd欧美风情| www.精品av.com| 久久久精品视频成人| 欧美激情中文字幕乱码免费| 日韩在线观看免费网站| 成人女保姆的销魂服务| 久久影院资源网| 国产一区二区三区在线免费观看| 久久成年人视频| 日韩av在线不卡| 精品亚洲一区二区三区在线播放| 欧美激情亚洲另类| 欧美精品免费在线观看| 国产精品私拍pans大尺度在线| 午夜免费在线观看精品视频| 69精品小视频| 久久久久久香蕉网| 视频在线一区二区| 久久精品人人做人人爽| 国产精品视频不卡| 中文字幕一区二区三区电影| 亚洲人高潮女人毛茸茸| 欧美性猛交xxxx富婆弯腰| 久久av在线播放| 国产精品视频网| 欧美激情2020午夜免费观看| 国产精品主播视频| 精品国产电影一区| 亚洲午夜国产成人av电影男同| 精品中文字幕视频| 91在线观看免费高清完整版在线观看| 丝袜情趣国产精品| 在线电影中文日韩| 在线一区二区日韩| 亚洲视频国产视频| 国产精品扒开腿做爽爽爽的视频| 国产亚洲视频在线| 日韩电影在线观看中文字幕| 欧美视频免费在线观看| 中文字幕久久亚洲| 丝袜美腿精品国产二区| 日韩免费在线免费观看| 国产精品自拍偷拍视频| 777午夜精品福利在线观看| 亚洲香蕉成人av网站在线观看| 最近中文字幕日韩精品| 欧美在线不卡区| 日韩成人激情影院| 亚洲福利影片在线| 欧美亚洲另类在线| 国产精品高潮呻吟久久av黑人| 日韩精品视频免费专区在线播放| 欧美理论电影在线观看| 国产精品久久99久久| 欧美电影免费观看高清| 久久影院模特热| 国产精品国产亚洲伊人久久| 欧美精品电影免费在线观看| 亚洲综合精品伊人久久| 最近2019免费中文字幕视频三| 5252色成人免费视频| 日本久久中文字幕| 91免费精品视频| 成人妇女免费播放久久久| 亚洲免费电影一区| 欧美大奶子在线| 97国产真实伦对白精彩视频8| 中文字幕日韩综合av| 亚洲四色影视在线观看| 欧美成人精品h版在线观看| 亚洲人线精品午夜| 久久精品久久久久久国产 免费| 欧美一级片久久久久久久| 久久精品免费电影| 一区二区欧美亚洲| 精品国偷自产在线视频99| 亚洲欧美激情精品一区二区| 国产视频在线观看一区二区| 中文字幕av一区中文字幕天堂| 欧美成人一二三| 自拍偷拍亚洲在线| 亚洲美女免费精品视频在线观看| 精品久久久久久中文字幕大豆网| 国产成人拍精品视频午夜网站| 久精品免费视频| 亚洲石原莉奈一区二区在线观看| 日韩中文字幕在线视频播放| 色黄久久久久久| 日韩精品在线视频观看| 成人国产精品免费视频| 亚洲有声小说3d| 日韩一二三在线视频播| 最近2019年手机中文字幕| 91色精品视频在线| 久久久久国产精品www| 久久久久五月天| 日韩中文av在线| 久久久久久欧美| 国产盗摄xxxx视频xxx69| 中文字幕欧美专区| 亚洲精品福利在线观看| 日韩欧美有码在线| 一区二区三区www| 亚洲va欧美va在线观看| 狠狠躁天天躁日日躁欧美| 日韩av综合网站| 国产91精品最新在线播放| 国产亚洲成av人片在线观看桃| 日本精品视频在线播放| 狠狠躁18三区二区一区| 孩xxxx性bbbb欧美| 亚洲精品www久久久久久广东| 亚洲免费中文字幕| 91精品免费久久久久久久久| 久久精品国产一区二区电影| 亚洲欧美成人一区二区在线电影| 亚洲欧美精品中文字幕在线| 色伦专区97中文字幕| 久久精品国产精品| 91成人福利在线| 亚洲影院色在线观看免费| 8090成年在线看片午夜| 97久久精品人搡人人玩| 国产亚洲精品久久| 欧美专区在线播放| 97在线观看视频国产| 欧洲美女7788成人免费视频| 国产精品自拍偷拍| 日韩a**中文字幕| 欧美裸体xxxx极品少妇软件| 中文日韩电影网站| 亚洲精品永久免费精品| 欧美人在线观看| 亚洲精品国产精品自产a区红杏吧| 91国内免费在线视频| 国产一区二区三区18| 精品亚洲永久免费精品| 色中色综合影院手机版在线观看| 富二代精品短视频| 在线亚洲午夜片av大片| 欧美一区二区大胆人体摄影专业网站| 成人av在线网址| 日韩的一区二区| 欧美xxxx18性欧美| 国产亚洲人成网站在线观看| 91九色视频导航| 亚洲一区二区少妇| 成人精品视频久久久久| 国产精品第二页| 91av视频在线免费观看| 日韩美女写真福利在线观看| 国产成人福利夜色影视|