首页 > 其他分享 >五、字典结构

五、字典结构

时间:2022-10-31 09:58:11浏览次数:40  
标签:function Dictionay items dict key 字典 结构

字典结构

一. 认识字典

字典的介绍

  • 生活中的字典
    • 中文字典我们可以根据拼音去查找汉字, 并且找到汉字对应的词以及解释.
    • 英文字典也是类似, 根据英文字母找到对应的单词, 再查看其翻译和应用场景.
    • 很多编程语言中都有字典的概念
  • 字典有什么特点呢?
    • 字典的主要特点是一一对应的关系.
    • 比如保存一个人的信息, 在合适的情况下取出这些信息.
    • 使用数组的方式: [18, "Coderwhy", 1.88]. 可以通过下标值取出信息.
    • 使用字典的方式: {"age" : 18, "name" : "Coderwhy", "height": 1.88}. 可以通过key取出value
  • 字典的映射关系:
    • 有些编程语言中称这种映射关系为字典, 因为它确实和生活中的字典比较相似. (比如Swift中Dictionary, Python中的dict)
    • 有些编程语言中称这种映射关系为Map, 注意Map在这里不要翻译成地图, 而是翻译成映射. (比如Java中就有HashMap&TreeMap等)
  • 字典和数组:
    • 字典和数组对比的话, 字典可以非常方便的通过key来搜索对应的value, key可以包含特殊含义, 也更容易被人们记住.
  • 字典和对象:
    • 很多编程语言(比如Java)中对字典和对象区分比较明显, 对象通常是一种在编译期就确定下来的结构, 不可以动态的添加或者删除属性. 而字典通常会使用类似于哈希表的数据结构去实现一种可以动态的添加数据的结构.
    • 但是在JavaScript中, 似乎对象本身就是一种字典. 所有在早期的JavaScript中, 没有字典这种数据类型, 因为你完全可以使用对象去代替.
    • 但是这里我们还是按照其他语言经常使用字典的方式去封装一个字典类型, 方便我们按照其他语言的方式去使用字典. (虽然本质上它内部还是用了一个对象, 后面学习完哈希表我会简单谈一下对象和哈希表的关系)

创建字典类

  • 我们向之前封装集合一样, 封装一个字典的构造函数

    // 创建字典的构造函数
    function Dictionay() {
        // 字典属性
        this.items = {}
        
        // 字典操作方法
    }
    
  • 代码解析:

    • 非常简单, 创建一个Dictionary的构造函数, 用于我们字典的封装.
    • 在字典中, 我们使用了一个items属性, 该属性是一个Object对象.
    • 也就是我们的字典是基于Object封装的, 这个不难理解: 就像我们之前封装Stack和Queue是基于数组的一样.
    • 后面我们在添加字典相关的操作

二. 操作字典

我们之前封装的数据结构, 都有封装各种操作, 字典也是一样

常见的操作

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

操作的实现

  • 我们将这些方法放在一起实现

    // 创建字典的构造函数
    function Dictionay() {
        // 字典属性
        this.items = {}
    
        // 字典操作方法
        // 在字典中添加键值对
        Dictionay.prototype.set = function (key, value) {
            this.items[key] = value
        }
    
        // 判断字典中是否有某个key
        Dictionay.prototype.has = function (key) {
            return this.items.hasOwnProperty(key)
        }
    
        // 从字典中移除元素
        Dictionay.prototype.remove = function (key) {
            // 1.判断字典中是否有这个key
            if (!this.has(key)) return false
    
            // 2.从字典中删除key
            delete this.items[key]
            return true
        }
    
        // 根据key去获取value
        Dictionay.prototype.get = function (key) {
            return this.has(key) ? this.items[key] : undefined
        }
    
        // 获取所有的keys
        Dictionay.prototype.keys = function () {
            return Object.keys(this.items)
        }
    
        // 获取所有的value
        Dictionay.prototype.values = function () {
            return Object.values(this.items)
        }
    
        // size方法
        Dictionay.prototype.size = function () {
            return this.keys().length
        }
    
        // clear方法
        Dictionay.prototype.clear = function () {
            this.items = {}
        }
    }
    
  • 代码解析:

    • 代码比较简单, 和之前实现的Set也比较类似, 不再深度解析.

字典的使用

  • 我们来使用和测试一下字典类:

    // 创建字典对象
    var dict = new Dictionay()
    
    // 在字典中添加元素
    dict.set("age", 18)
    dict.set("name", "Coderwhy")
    dict.set("height", 1.88)
    dict.set("address", "广州市")
    
    // 获取字典的信息
    alert(dict.keys()) // age,name,height,address
    alert(dict.values()) // 18,Coderwhy,1.88,广州市
    alert(dict.size()) // 4
    alert(dict.get("name")) // Coderwhy
    
    // 字典的删除方法
    dict.remove("height")
    alert(dict.keys())// age,name,address
    
    // 清空字典
    dict.clear()
    

标签:function,Dictionay,items,dict,key,字典,结构
From: https://www.cnblogs.com/codehaoran/p/16843261.html

相关文章

  • 【XSY3979】数据结构(分治,剪枝)
    题面数据结构题解挺神奇的一道题。正解是对\(y\)坐标分治。每次考虑\(y\)坐标在\([l,mid]\)范围内的红点和\(y\)坐标在\([mid+1,r]\)范围内的蓝点匹配成点......
  • 数据结构与算法-树
    树的表示与术语节点的度、树的度、叶子节点、父亲节点、兄弟节点、堂兄节点、祖先节点、子孙节点、节点层次、树的深度、路径、路径长度、分支...二叉树二叉树的性质......
  • 【数据结构】(一)线性表
    约定:Status是函数的返回值类型,其值是函数结果状态代码typedef描述存储结构的类型定义ElemType表示数据元素类型   一.顺序表1.1顺序表的初始化动态分......
  • vue-admin-template快速开发框架,菜单栏不显示层级结构
    问题现象路由页面效果解决办法路由添加中配置alwaysShow:true,//树形层级显示页面效果......
  • JVM(一)-内存结构
    我们都知道,我们写的Java程序需要先经过编译,生成了.class文件(字节码文件)。然而,计算机并不能直接解释.class文件里面的内容,这时候就需要一个能加载、解释.class文件并且能按......
  • Day5:Python基础:字典方法一
    1、字典增加键值Dic={'Age':18,'Name':'Jie','Sex':'male'}#增Dic['High']=160print(Dic)2、字典键值修改Dic={'Age':18,'Name':'Jie','Sex':'male'}......
  • 结构体的内存对齐
    结构体对齐内存的规则是什么?如何计算一个结构体占用空间?内存对齐规则结构体的内存对齐,遵循以下三个原则(以下“首地址”指相对于结构体地址的偏移量):第一个成员的首地......
  • 【数据结构-数组】数组的相关算法
    目录1无序数组的排序——快速排序1.1升序排序1.2降序排序2有序数组的查找——折半查找(二分查找)2.1升序数组的查找2.2降序数组的查找3有序数组的合并——归并思想3.1......
  • 四、集合结构
    集合结构集合通常是由一组无序的、不能重复的元素构成和数学中的集合名次比较相似,但是数学中的集合范围更大一些,也允许集合中的元素重复在计算机中,集合通常表示的结构......
  • C语言之存储类,枚举,结构体,共用体,typedef
    目录1存储类1.1auto存储类1.2register存储类1.3static存储类1.4extern存储类2枚举2.1定义2.2操作枚举2.2.1用for循环遍历枚举3结构体3.1定义结构3.2操作结构......