js查找数组的重复项和对应的下标

处理逻辑,每一项都跟后面的每一项进行对比,所以是要遍历2次的

function getSameItem() {
          
   
  var arr = [12, 12, 9, 12, 4, 5, 4, 4, 3, 5, 3]  // 要查找的数组
  var obj = {
          
   } // 重复项组成的对象
  arr.forEach((item, index) => {
          
   
      arr.forEach((item1, index1) => {
          
   
        // 每一项要后面的每一项进行对比
          if (index1 > index && item == item1) {
          
   
              if (!obj[item]) {
          
    // 设置初始数组
                  obj[item] = []
                  obj[item].push(index)
                  obj[item].push(index1)
              } else {
          
   
                  obj[item].push(index)
                  obj[item].push(index1)
              }
          }
      })
  })
  Object.keys(obj).forEach((item, index) => {
          
   
      obj[item] = [...new Set(obj[item])] //去掉重复下标,有重复下标是因为push了index和index1
      if(obj[item].length > 1) {
          
   
          console.log(有重复项:, item, 下标为:, obj[item],  重复数量为:, obj[item].length,=======)
      }
  })
}
经验分享 程序员 微信小程序 职场和发展