将数字插入排序的数字数组JavaScript
我们需要编写一个JavaScript函数,该函数将数字的排序数组作为第一个参数,将单个数字作为第二个参数。
该函数应将指定为第二个参数的数字推入数组,而不会扭曲元素的排序。
我们需要这样做而不创建另一个数组。
示例
const arr = [6, 7, 8, 9, 12, 14, 16, 17, 19, 20, 22];
const num = 15;
const findIndex = (arr, val) => {
let low = 0, high = arr.length;
while (low < high) {
let mid = (low + high) >>> 1;
if (arr[mid] < val) {
low = mid + 1;
}else {
high = mid
}
};
return low;
};
const insertAt = (arr = [], num) => {
const position = findIndex(arr, num);
for(let i = position; typeof arr[i] !== 'undefined'; i++){
//不使用第三个变量num+=arr[i]进行交换;
arr[i] = num - arr[i];
num -= arr[i];
};
arr.push(num);
};
insertAt(arr, num);
console.log(arr);输出结果
这将产生以下输出-
[ 6, 7, 8, 9, 12, 14, 15, 16, 17, 19, 20, 22 ]
热门推荐
10 小红书平安祝福语简短
11 生日祝福语大全女孩简短
12 收生日红包祝福语 简短
13 领证幽默祝福语简短
14 法考面试祝福语简短
15 老哥出门祝福语简短语
16 送灯祝福语简短独特
17 幼儿狗年祝福语大全简短
18 好听的元旦简短祝福语