国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > JS > 正文

JavaScript實現二分查找實例代碼

2024-05-06 16:35:19
字體:
來源:轉載
供稿:網友

二分查找的前提為:數組、有序。邏輯為:優先和數組的中間元素比較,如果等于中間元素,則直接返回。如果不等于則取半繼續查找。

/** * 二分查找,遞歸實現。 * @param target * @param arr * @param start * @param end * @returns {*} */function binarySearch(target,arr,start,end) {  var start  = start || 0;  var end   = end || arr.length-1;  var mid = parseInt(start+(end-start)/2);  if(target==arr[mid]){    return mid;  }else if(target>arr[mid]){    return binarySearch(target,arr,mid+1,end);  }else{    return binarySearch(target,arr,start,mid-1);  }  return -1;}/** * 有序的二分查找,返回-1或存在的數組下標。不使用遞歸實現。 * @param target * @param arr * @returns {*} */function binarySearch(target,arr) {  var start  = 0;  var end   = arr.length-1;  while (start<=end){    var mid = parseInt(start+(end-start)/2);    if(target==arr[mid]){      return mid;    }else if(target>arr[mid]){      start  = mid+1;    }else{      end   = mid-1;    }  }  return -1;}

寫完有序,自然而然的想到了無序的情況如何使用二分查找呢?馬上想到先使用快排分組,分好組再二分。代碼如下:

/** * 無序的二分查找。返回true/false * @param target * @param arr * @returns {boolean} */function binarySearch(target,arr) {  while (arr.length>0){    //使用快速排序。以mid為中心劃分大小,左邊小,右邊大。    var left  = [];    var right  = [];    //選擇第一個元素作為基準元素(基準元素可以為任意一個元素)    var pivot  = arr[0];    //由于取了第一個元素,所以從第二個元素開始循環    for(var i=1;i<arr.length;i++){      var item = arr[i];      //大于基準的放右邊,小于基準的放左邊      item>pivot ? right.push(item) : left.push(item);    }    //得到經過排序的新數組    if(target==pivot){      return true;    }else if(target>pivot){      arr   = right;    }else{      arr   = left;    }  }  return false;}

寫完用快速排序實現的無序二分查找,仔細想了一下該算法的時間復雜度,發現還不如直接一個for循環來得快

以上所述是小編給大家介紹的JavaScript實現二分查找實例代碼,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對VeVb武林網網站的支持!


注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 宁陵县| 渝中区| 乌鲁木齐县| 张北县| 通城县| 永靖县| 平乐县| 鹤壁市| 沐川县| 乌兰浩特市| 山丹县| 墨脱县| 大理市| 类乌齐县| 顺平县| 镇康县| 晋宁县| 永春县| 霍林郭勒市| 中江县| 吴旗县| 抚顺市| 武威市| 朝阳区| 纳雍县| 辽宁省| 宿州市| 措勤县| 梨树县| 陆川县| 定结县| 黄梅县| 会昌县| 中方县| 东安县| 深水埗区| 桑日县| 中宁县| 泰来县| 茶陵县| 青川县|