JavaScript数据结构与算法学习笔记之字典

本文深入探讨了字典数据结构的定义与实现,字典是一种存储键值对的高效数据结构,提供了如set、remove、has等关键操作。文章详细介绍了字典类的构造与方法,包括添加、删除、查询元素及获取所有键值的功能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、字典定义

集合表示一组互不相同的元素(不重复的元素)。在字典中,存储的是[键,值]对,其中键名是用来查询特定元素的。字典和集合很相似,集合以[值,值]的形式存储元素,字典则是以[键,值]的形式来存储元素。字典也称作映射

Dictionary类的骨架:

function Dictionary() {
     var items = {};
}

声明一些映射/字典所能使用的方法。
 set(key,value):向字典中添加新元素。
 remove(key):通过使用键值来从字典中移除键值对应的数据值。
 has(key):如果某个键值存在于这个字典中,则返回true,反之则返回false。
 get(key):通过键值查找特定的数值并返回。
 clear():将这个字典中的所有元素全部删除。
 size():返回字典所包含元素的数量。与数组的length属性类似。
 keys():将字典所包含的所有键名以数组形式返回。
 values():将字典所包含的所有数值以数组形式返回。

function Dictionary(){
    var items={};
    this.has = function(key){
        return key in items;
    }
    this.set = function(key,value){
        items[key] = value;
    }

    this.remove = function(key){
        if(this.has(key)){
            delete items[key];
            return true;
        }
        return false;
    }
    this.get = function(key){
        return this.has(key) ? items[key] : undefined;
    }

    this.values = function(){
        var values = {};
        for(var k in items){
            if(this.has(k)){
                values.push(items[k]);
            }
        }
        return values;
    }
    this.getItems = function(){
        return items;
    }
    //想移除集合中的所有值
    this.clear = function(){
        items = {};
    }

    //size方法(返回集合中有多少项)
    this.size = function(){
        //JavaScript的Object类有一个keys方法,它返回一个包含给定对象所有属性的数组。在这种
        //情况下,可以使用这个数组的length属性(行{4})来返回items对象的属性个数。
        return Object.keys(items).length;
    }
    
}

var dictionary = new Dictionary();
dictionary.set('Gandalf', 'gandalf@email.com');
dictionary.set('John', 'johnsnow@email.com');
dictionary.set('Tyrion', 'tyrion@email.com');
console.log(dictionary.has('Gandalf'));

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值