javascript 算法

快速排序

var arr = new Array()
for(var i = 0;i<20;i++){
    arr.push(Math.floor(Math.random()*100))
}
console.log(quickSort(arr))
function quickSort(arr){
    if(arr.length<=1){return arr}
    var min = arr[0]//以第一個為基準
    arr.shift()//刪除第一個
    var left = [],right = []
    for(var i = 0;i<arr.length;i++){
        if(arr[i]<=min){
            left.push(arr[i])
        }else{
            right.push(arr[i])
        }
    }
    return [].concat(arguments.callee(left),[min],arguments.callee(right))
}

冒泡排序

var arr = new Array()
for(var i = 0;i<20;i++){
    arr.push(Math.floor(Math.random()*100))
}
sort(arr)
console.log(arr)
function sort(arr){
    for(var i = 0;i<arr.length;i++){
        for(var j = i+1;j<arr.length;j++){
            if(arr[i]>=arr[j]){
                var temp = arr[i]
                arr[i] = arr[j]
                arr[j]=temp
            }
        }

    }

}

二分查找

var arr = new Array()
for(var i = 0;i<20;i++){
    arr.push(Math.floor(Math.random()*100))
}
sort(arr)//先排序
console.log(arr)
console.log(search(arr,56))
function search(arr,num){
    var min = 0,max=arr.length
     while(min<=max){
            var mid = Math.floor((max+min)/2); //中間值
            if(arr[mid]<num){
                min = mid+1;
            }else if(arr[mid]>num){
                max = mid-1;
            }else{
                return mid; 
            }
        }
        return -1;   //沒找到返回-1
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關(guān)閱讀更多精彩內(nèi)容

  • 本文總結(jié)常見的算法,并用JavaScript實現(xiàn) Array對象的sort()函數(shù)常用比較函數(shù)compareFun...
    jasonhsu9閱讀 149評論 0 1
  • 什么是隊列 隊列是一種列表,不同的是隊列只能在隊尾插入元素,在隊首刪除元素。隊列用于存儲按 順序排列的數(shù)據(jù),先進先...
    打鐵大師閱讀 730評論 0 1
  • 1、區(qū)間求值算法(Sum All Numbers in a Range) 我們會傳遞給你一個包含兩個數(shù)字的數(shù)組。返...
    Iris_mao閱讀 1,624評論 0 2
  • 1、翻轉(zhuǎn)字符串(Reverse a String) 翻轉(zhuǎn)字符串先把字符串轉(zhuǎn)化成數(shù)組,再借助數(shù)組的reverse方法...
    Iris_mao閱讀 736評論 1 3
  • 如果,你想挽著心愛的人踏著紅葉緩緩漫步;如果,你想尋一個像夢一樣的地方隨意徜徉;如果,你想找一個幽靜的去...
    伊清歡閱讀 651評論 3 4

友情鏈接更多精彩內(nèi)容