c++ map是有序还是无序的_实现有序map之go「建议收藏」

c++ map是有序还是无序的_实现有序map之go「建议收藏」GoMap介绍Go中Map是一种无序的键值对的集合。Map最重要的一点是通过key来快速检索数据,key类似于索引,指向数据的值。Map是一种集合,所以我们可以像迭代数组和切片那样迭代它。不过,Map是无序的,我们无法决定它的返回顺序,这是因为Map是使用链式hash表来实现的。c++中的实现在C++STL中map采用红黑树实现,可以实现有序的Map.Go中实现实现原理这个实现方法的…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

Go Map介绍

Go 中 Map是一种无序的键值对的集合。Map最重要的一点是通过key来快速检索数据,key类似于索引,指向数据的值。Map是一种集合,所以我们可以像迭代数组和切片那样迭代它。不过,Map是无序的,我们无法决定它的返回顺序,这是因为Map是使用链式hash表来实现的。

c++中的实现

在C++ STL 中map 采用红黑树实现,可以实现有序的Map.

Go 中实现

实现原理

这个实现方法的主要的方法是用空间换取时间。通过list 和 map 两种数据结构,保存相同的一份数据。list 用来做顺序遍历,map 用来做查找,删除操作

实现代码

package main

import (

“container/list”

“fmt”

)

type Keyer interface {

GetKey() string

}

type MapList struct {

dataMap map[string]*list.Element

dataList *list.List

}

func NewMapList() *MapList {

return &MapList{

dataMap: make(map[string]*list.Element),

dataList: list.New(),

}

}

func (mapList *MapList) Exists(data Keyer) bool {

_, exists := mapList.dataMap[string(data.GetKey())]

return exists

}

func (mapList *MapList) Push(data Keyer) bool {

if mapList.Exists(data) {

return false

}

elem := mapList.dataList.PushBack(data)

mapList.dataMap[data.GetKey()] = elem

return true

}

func (mapList *MapList) Remove(data Keyer) {

if !mapList.Exists(data) {

return

}

mapList.dataList.Remove(mapList.dataMap[data.GetKey()])

delete(mapList.dataMap, data.GetKey())

}

func (mapList *MapList) Size() int {

return mapList.dataList.Len()

}

func (mapList *MapList) Walk(cb func(data Keyer)) {

for elem := mapList.dataList.Front(); elem != nil; elem = elem.Next() {

cb(elem.Value.(Keyer))

}

}

type Elements struct {

value string

}

func (e Elements) GetKey() string {

return e.value

}

func main() {

fmt.Println(“Starting test…”)

ml := NewMapList()

var a, b, c Keyer

a = &Elements{“Alice”}

b = &Elements{“Bob”}

c = &Elements{“Conrad”}

ml.Push(a)

ml.Push(b)

ml.Push(c)

cb := func(data Keyer) {

fmt.Println(ml.dataMap[data.GetKey()].Value.(*Elements).value)

}

fmt.Println(“Print elements in the order of pushing:”)

ml.Walk(cb)

fmt.Printf(“Size of MapList: %d \n”, ml.Size())

ml.Remove(b)

fmt.Println(“After removing b:”)

ml.Walk(cb)

fmt.Printf(“Size of MapList: %d \n”, ml.Size())

}

优点

红黑树的插入、删除、查找的复杂度都是 O(logn), 而这个实现插入查找删除的复杂度都是 O(1), 可以说是一种非常好的数据结构。

缺点

使用了两个数据结构,空间占用稍微大了一点。但是和树的实现比,这个占用也不算非常大

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/190163.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 计算机网络ip地址划分范围,ip地址分类及范围划分有哪些

    计算机网络ip地址划分范围,ip地址分类及范围划分有哪些ip地址分为网络地址和主机地址,IP地址是真正网络中计算机的身份标识。手机的IP是手机上网使用的地址,不论是手机还是电脑,一个网段里面只有一个IP,所以每个人手机的IP都是唯一的,当用手机发朋友圈时,就会显示手机ip地址所在地,因此有些人会想要修改手机ip地址。那么ip地址可分为哪几类?其范围是怎么划分的?如何修改手机ip地址?下面小编为大家解答手机ip地址修改方法及ip地址分类及范围划分等知识。…

    2022年5月29日
    50
  • 电脑使用哪个录制视频软件比较好

    电脑使用哪个录制视频软件比较好如今社会从一个开放的年代发展为开放的信息时代,人们对于自我表达越发的大胆。追求标新立意,而视频正好迎合了人群的需要。视频的表现方式比图纸更加直观具有冲击力,更展现更加生动丰富的内容。想要录制视频其实不难,只需要一款专业的录制视频软件就可以帮搜我们达到我们想要的效果。使用工具:电脑(有网络)迅捷屏幕录像工具操作步骤:1、首先电脑在线进入百度浏览器搜索迅捷屏幕录像,并且安装在电脑上进行运行。…

    2022年6月16日
    27
  • POENIX的BIOS报警声

    POENIX的BIOS报警声

    2021年7月24日
    61
  • 12306自动刷票下单-登录篇(一)

    12306自动刷票下单-登录篇(一)12306网站推出图片验证码以后,对于抢票软件就提出了更高的要求,本篇并不涉及自动识别验证码登录(主要是博主能力所限),提供一个途径-打码平台,这个几乎是可以激活成功教程所有验证码了,本篇主要是分享一下12306网站登录的流程的学习,勿吐槽,有问题请指正,博主也是刚开始接触爬虫,大家共勉共勉。废话不多说了,直接干吧 首先打开12306登录页面https://kyfw.12306.cn/otn/login/…

    2025年8月15日
    4
  • 浅谈 &0xFF操作

    浅谈 &0xFF操作在java.io.FilterOutputStream.DataOutputStream:与机器无关地写入各种类型的数据以及String对象的二进制形式,从高位开始写。这样一来,任何机器上任何DataInputStream都能够读取它们。所有方法都以“write”开头,例如writeByte(),writeFloat()等。java.io.FilterOutputStream.PrintSt

    2022年6月19日
    30
  • 类文件介绍

    类文件介绍

    2020年11月20日
    219

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号