在不同的数组中找到相同的数组元素,并将其重命名为增量



在另一个数组中查找相同的数组元素并将其重命名为增量。在下面的脚本中,我想动态地将相同的元素增加到+1,而不需要手动输入"motor"将其重命名为"motor ">

例如,用例

//original array
["car","motor","bicycle","tricyle","motor"]
//result should be 
["car","motor","bicycle","tricyle","motor 1"]

这是我试过的脚本

let _temparr = ["car","motor","bicycle","tricyle","motor"]
let _newarr  = new Array();
let counter = 0;
for(let i = 0 ; i < _temparr.length;i++){

// Push _temparr element to _newarr
for(let a = 0; a < _newarr.length; a++){
// if _newarr consist of motor , increment counter +1 and push as "Motor 1"
if(_newarr[i] === "motor"){
counter++
_newarr.push(_temparr[i] + counter)
}
}
_newarr.push(_temparr[i])

我得出的逻辑是,如果在_temparray中找到相同的元素,我将循环_temparray并将其推入一个新的数组:_newarr,在_newarr的第一个循环中。计数器将递增。但我不确定什么是最好的做法。我发现了一些关于使用const found = arr1.some(r=> arr2.includes(r))的主题,但如果它具有相同的元素

,则会删除。

您可以为每个单词/元素保留一个计数器,并使用.map创建新数组,根据需要更新每个元素:

const counter = new Map();
console.log(
["car","motor","bicycle","tricyle","motor"].map(
element => {
if (!counter.has(element)) {
counter.set(element, 1);
return element;
}
const count = counter.get(element);
counter.set(element, count+1);
return element + " " + count;
}
)
);

也许你可以考虑使用Map:

const originalArray = ["car", "motor", "bicycle", "tricyle", "motor"];
const newArray = [];
const counter = new Map();
originalArray.forEach(item => {
if (counter.has(item)) {
newArray.push(`${item} ${counter.get(item)}`);
counter.set(item, counter.get(item) + 1);
} else {
newArray.push(item);
counter.set(item, 1);
}
});
console.log(newArray);

最新更新