温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

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

发布时间:2020-06-25 21:49:10 来源:网络 阅读:347 作者:菜鸟不菜么 栏目:web开发
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;
            }

        }
向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI