我们需要编写一个JavaScript函数,该函数采用数字数组arr作为第一个也是唯一的参数。
移动包括选择任意arr [i],然后将其递增1。我们的函数应该返回最少的移动次数,以使数组arr中的每个值唯一。
例如,如果函数的输入为-
const arr = [12, 15, 7, 15];
那么输出应该是-
const output = 1;
因为如果我们将15增至16,则数组将包含所有唯一元素。
为此的代码将是-
const arr = [12, 15, 7, 15]; const makeUnique = (arr = []) => { arr.sort((a, b) => a - b); let count = 0; for (let i = 1; i < arr.length; i++) { if (arr[i] <= arr[i - 1]) { const temp = arr[i] arr[i] = arr[i - 1] + 1 count += arr[i] - temp }; }; return count; }; console.log(makeUnique(arr));
输出结果
控制台中的输出将是-
1