首页 > 编程语言 > 详细

使用冒泡法进行排序然后用二分查找法找出33的位置 JS

时间:2019-10-11 20:08:54      阅读:105      评论:0      收藏:0      [点我收藏+]
var data = [33, 86, 12, 9, 66, 5, 10, 45, 11, 3]; function sort(data){ var i=0; while(i<data.length-1){ for(var j=0;j<data.length-i-1;j++){ if(data[j]>data[j+1]){ var x=data[j]; data[j]=data[j+1]; data[j+1]=x; } } i++; } } sort(data) BinarySearch(data,33) function BinarySearch(arr, target) { let s = 0; let e = arr.length - 1; let m = Math.floor((s + e) / 2); let sortTag = arr[s] <= arr[e];//确定排序顺序 while (s < e && arr[m] !== target) { if (arr[m] > target) { sortTag && (e = m - 1); !sortTag && (s = m + 1); } else { !sortTag && (e = m - 1); sortTag && (s = m + 1); } m = Math.floor((s + e) / 2); } if (arr[m] == target) { console.log(‘找到了,位置%s‘, m); return m; } else { console.log(‘没找到‘); return -1; } }

使用冒泡法进行排序然后用二分查找法找出33的位置 JS

原文:https://blog.51cto.com/8818968/2441679

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!