/* * @Description: 折半插入排序【JavaScript版本】 * @Version: Beta1.0 * @Author: 【B站&公众号】Rong姐姐好可爱 * @Date: 2021-03-27 12:35:17 * @LastEditors: 【B站&公众号】Rong姐姐好可爱 * @LastEditTime: 2021-03-27 12:50:00 */ /** * 折半插入排序 * @param {Array} arr 待排序数组 * @param {int} len 数组长度 */ function binaryInsertSort(arr,len){ // 数组长度校验【非必须】 len=arr.length===len?len:arr.length for(let i=1;ihighIndex;--j){ arr[j+1]=arr[j] } arr[highIndex+1]=temp; } // 返回经过折半插入排序处理的有序数组 return arr; } const dealArr=[5,2,7,3,18,8,12,1] console.log('插入排序前:',dealArr) const sortResult=binaryInsertSort(dealArr,7) console.log('插入排序后:',sortResult)