求出数组中出现最多的元素以及出现的次数,去重的一点小思路

 <script>

        // 相同点:元素名相同 需求:相同递增1 自增

        // 思路:建立空对象 以元素名为下标 检测对象里面 未存在:undefined 添加元素1 存在即自增1

        let arr = ['a', 'b', 'a', 's', 'f', 'g', 'g', 'g', 'h', 'j', 'j', 'k', 'k', 'g', 'f', 'd', 'd',

            's', 's', 's', 's', 's', '3', '4', '4', '4', '3', '4', '3'];

        // 定义一个空数组

        let obj = {}

        // 遍历arr

        for (let i = 0; i < arr.length; i++) {

            // 以arr{[i]为下标 不存在就添加一个数值 1

            if (obj[arr[i]] == undefined) {

                obj[arr[i]] = 1

            } else {

                // obj[下标]已存在 自增1 

                obj[arr[i]]++

            }

        }

        // 输出obj

        console.log(obj)

        // 定义空擂

        let max = -Infinity

        // 定义下标的名字

        let maxName

        // 遍历obj      用for in  循环输出obj[j]

        for (let j in obj) {

            if (obj[j] > max) {

                max = obj[j]

                maxName = j

            }

        }

        console.log(max)        // 出现最多次数

        console.log(maxName)    // 出现次数最多的元素名

        // 相同点:元素名相同 需求: 去重   

        // 思路:建立空对象 以元素名为下标 元素等同下标则跳过(该下标为arr[i])

        let newObj = {}

        // 建立另外一个新的数组 在去重同时装起非重元素

        let newArr = []

        for (let i = 0; i < arr.length; i++) {

            if (newObj[arr[i]] == undefined) {

                newObj[arr[i]] = arr[i]

                // 同时把 newObj[arr[i]] 按照顺序装到newArr数组里面

                newArr[newArr.length] = newObj[arr[i]]

            }

        }

        console.log(newArr)

    </script>

// 新手菜鸡

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值