DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> 關於JavaScript >> JavaScript 冒泡排序和選擇排序的實現代碼
JavaScript 冒泡排序和選擇排序的實現代碼
編輯:關於JavaScript     

廢話不多說了,直接給大家貼代碼了,具體代碼如下所述:

var array = [1,2,3,4,5]; // ---> 服務
//效率 ---> 針對一個有序的數組 效率最高
//標志 true false 
for(var j = 0; j < array.length - 1;j++ ){
//- j 每次排序完成之後 後面減少比較的次數
var isTrue = true; //如果數組本身就是升序,則直接輸出
for(var i = 0; i < array.length - j - 1;i++){
if(array[i] > array[i+1])
{
var temp = array[i];
array[i] = array[i+1];
array[i+1] = temp;
isTrue = false;
}
}
document.write(array);
if(isTrue){
break;
}
}
var array = [12,34,4,6,20];
//length - 1 j = 0 - length - 1
for(var j = 0; j < array.length - 1;j++){
var min = array[j]; // 1 3 34 4 345 5
var minIndex = j;
for(var i = j + 1; i < array.length;i++){
if(array[i] < min){
min = array[i];
minIndex = i;
}
}
if(minIndex != j){
var temp = array[minIndex];
array[minIndex] = array[j];
array[j] = temp;
}
}

下面在看下Javascript實現三種排序:冒泡排序、選擇排序、插入排序的代碼

<script type="text/javascript">
    var a;
    a = [66, 53, 11, 5, 4, 3, 2, 1];
    /*冒泡排序*/
    (function maopaopaixu() {
      for (var i = 0; i < a.length - 1; i++) {//比較的次數是length-1
        for (var j = 0; j < a.length - 1 - i; j++) {
          if (a[j] > a[j + 1]) {
            var tmp = a[j];
            a[j] = a[j + 1];
            a[j + 1] = tmp;
          }
        }
      }
      alert(a);
    })();
    a = [66, 53, 11, 5, 4, 3, 2, 1];
    /*選擇排序*/
    (function xuanzepaixu() {
      var min/*最小項的索引*/, tmp;
      for (var out = 0; out < a.length - 1; out++) {//比較的次數是length-1
        min = out;
        for (var inner = out + 1; inner < a.length; inner++) {//這裡是a.length,不是a.lenght-1,因為後者會導致右數第2項沒法參與排序。
          if (a[inner] < a[min]) {
            min = inner;
          }
          //將最小的項移動到左側
          tmp = a[out];
          a[out] = a[min]
          a[min] = tmp;
        }
      }
      alert(a);
    })();
    a = [66, 53, 11, 5, 4, 3, 2, 1];
    /*插入排序*/
    (function charupaixu() {
      for (var out = 1; out < a.length; out++) {
        var tmp = a[out];
        var inner = out;
        while (a[inner - 1] > tmp) {
          a[inner] = a[inner - 1];
          --inner;
        }
        a[inner] = tmp;
      }
      alert(a);
    })();
  </script>

以上所述是小編給大家介紹的JavaScript 冒泡排序和選擇排序的實現代碼,希望對大家有所幫助,如果大家有任何疑問歡迎給我留言,小編會及時回復大家!

XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved