-
千巷猫影
使用 Set 或数组或对象来跟踪已经看到的值,并使用 while 循环来获取新的唯一值const arr = [5, 5, 5, 4, 4];const seen = new Set();// only holds unique values, even when add duplicatesarr.forEach((n,i) => { while(seen.has(n)){ arr[i] = n = Math.floor(Math.random() * 10); } seen.add(n);});console.log(arr)
-
慕工程0101907
previousElements 包含 arr 中位于当前索引之前的元素,而 otherElements 包含 arr 中除当前索引之外的所有其他元素。如果已经有一个实例,则会生成一个新的随机数。然后将新的随机数与 arr 的所有其余元素进行比较,以避免更改数字的第一个实例。在提供的示例中,索引 3 将始终保持为 4。var arr = [5, 5, 5, 4, 4];for (let i = 0; i < arr.length; i++) { let previousElements = arr.slice(0, i); let otherElements = JSON.parse(JSON.stringify(arr)); otherElements.splice(3, 1); if (previousElements.includes(arr[i])) { arr[i] = Math.floor(Math.random() * 10); while (otherElements.includes(arr[i])) { arr[i] = Math.floor(Math.random() * 10); } }}console.log('arr: ' + JSON.stringify(arr));示例输出:[5,8,2,4,3]示例输出:[5,0,1,4,8]
-
海绵宝宝撒
这是解决方案:var arr = [5, 5, 5, 4, 4];const replaceduplicates=(arr)=>{ let i =1; while(i < arr.length -1 ){ const currentElement=arr[i] const indexOfcurrentElement= arr.indexOf(currentElement) if(indexOfcurrentElement > -1) { let newValue=Math.floor(Math.random() * 10 + arr[i-1]) while( arr.indexOf(newValue) > -1) { newValue=Math.floor(Math.random() * 10 ) } arr[i] = newValue; i++ } } return arr}//this is how I tested basically this will run for ever let found=falsewhile(!found ){ const arrResponse =replaceduplicates(arr) for (let i = 0; i < arrResponse.length; i++) { for (let j = i+1; j < arrResponse.length; j++) { if(arrResponse[i] == arrResponse[j]) found = true } } console.log('no duplicates')}
-
不负相思意
使用while循环而不是if语句来不断检查该值,直到它不等于先前的值。虽然您需要在将数字更改为随机数之后添加额外的检查,以查看该随机数是否已经不在数组中。const hasDuplicateNumbers = (number, numbers) => numbers.filter(item => item === number).length > 1;let arr = [5, 5, 5, 4, 4];for (let i = 0; i < arr.length; i++) { for (let j = i + 1; j < arr.length; j++) { if (i === j) { continue; } while(hasDuplicateNumbers(arr[j], arr)) { arr[j] = Math.floor(Math.random() * 10); } }}console.log(arr);