JS-集合、字典和散列表

集合

集合是一组无须且唯一不能重复的项组成的,可以看成没有顺序概念、重复元素的数组

class Set {
    constructor() {
        this.items = {}
    }
    has(element){
        return element in this.items
    }
    has_2(element){
        //hasOwnProperty该方法返回一个表明对象是否具有该属性的方法
       return Object.prototype.hasOwnProperty.call(this.items,element)
    }
    add(element){
        if(!this.has(element)){
            //添加一个元素时,把它同时作为键和值保存,因为这样有利于查询
            this.items[element] = element
            return true
        }
        return false
    }
    delete(element){
       if(this.has(element)){
           delete this.items[element]
           return true
       }
       return false
    }
    clear(){
        this.items={}
    }
    size(){
        //JavaScript的key()方法,它返回一个给定对象所有属性和对象的值
        //可以借用它的length属性
        return Object.keys(this.items).length
        //当然,还有其他方法来实现,用length变量来记录个数或者用迭代得出个数
    }
    values(){
        //返回对象所有属性值
        return Object.values(this.items)
    }
}

集合运算
并集

交集

差集

字典

散列表

附:
JS delete关键字

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

李和贵

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值