码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • golang有序map


    最近使用go开发排行榜的需求, 有些情况会用到有序map, 但是go竟然没有有序map的实现

    本着自己动手丰衣足食的原则, 就自己实现了一个

    原理

    原理比较简单, 主要结合了container/list双向链表和map

    使用双向链表存储key和value, 保证顺序, 使用map存储key和节点信息, 保证查找的时间复杂度

    在增加, 删除, 修改, 查询时保证了O(1)的复杂了, 感兴趣的同学可以查看源码, 多多给出更多优化意见

    安装

    go get -u github.com/shuaibingn/go-extension/ordered_map
    

    使用

    ```go
    package main
    
    import (
    	"fmt"
    	
    	"github.com/shuaibingn/go-extension/ordered_map"
    )
    
    func main() {
    	om := ordered_map.NewOrderedMap[string, string]() // 初始化有序map
    	om.Set("key1", "value1") // 设置key, value
    	om.Set("key2", "value2")
    	om.Set("key3", "value3")
    	
    	value, ok := om.Get("key1") // 获取key1的值
        fmt.Println(value, ok)
    	
    	om.Remove("key2") // 删除key2
    	
    	keys := om.Keys() // 获取所有的key
    	fmt.Println(keys)
    	
    	values := om.Values() // 获取所有的value
    	fmt.Println(values)
    	
    	// 有序map遍历
    	for item := range om.Iterator() {
    		fmt.Println(item.Key, item.Value)
        }
    	
    	om.Clear() // 清空有序map
    	fmt.Println(om.Len()) // 获取有序map的长度
    }
    
  • 相关阅读:
    Java 入门练习(16 - 20)
    信道数据传输速率、信号传播速度——参考《天勤计算机网络》
    uniApp初体验-从零开始注意事项
    贪心算法篇——经典题型
    爬虫逆向实战(31)-某花顺行情中心(cookie、补环境)
    软件和硬件之间的数据交互接口
    从实际案例聊聊Java应用的GC优化
    Spring6 - ioc
    【算法03】对数器
    使用vue-cl搭建SPA项目
  • 原文地址:https://blog.csdn.net/qq_36574108/article/details/143399308
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号