请教std::map<>::insert的用法

feng8180 2010-06-29 06:10:56
如果建了一个map,然后在里面依次插入了许多元素1,2,3,4,5,6.
现在如果想在元素3的后面插入一个元素7,有办法实现么?
我用std::map<>::insert(iterator ,value_type);方法以后,发现插入的元素跑到map的末尾了,而不是在iterator指示的位置。
...全文
1542 8 打赏 收藏 转发到动态 举报
写回复
用AI写文章
8 条回复
切换为时间正序
请发表友善的回复…
发表回复
rabbitgoat 2010-06-29
  • 打赏
  • 举报
回复
map会进行排序,推荐用list
liutengfeigo 2010-06-29
  • 打赏
  • 举报
回复
我虽然没看什么,。。但我知道这个该用vetor
cattycat 2010-06-29
  • 打赏
  • 举报
回复
map不能这么插入,你想在3后面插入7,考虑vector容器。map是红黑树,实际上是平衡二叉树,也就是按键值中续遍历是有序的。
pengzhixi 2010-06-29
  • 打赏
  • 举报
回复
[Quote=引用楼主 feng8180 的回复:]
如果建了一个map,然后在里面依次插入了许多元素1,2,3,4,5,6.
现在如果想在元素3的后面插入一个元素7,有办法实现么?
我用std::map<>::insert(iterator ,value_type);方法以后,发现插入的元素跑到map的末尾了,而不是在iterator指示的位置。
[/Quote]

请用顺序容器
jeremyhuang81 2010-06-29
  • 打赏
  • 举报
回复
std::map<>,默认是按照升序排列的。所以,你就相当于插到了最后。

你可以用list, vector解决啊。
  • 打赏
  • 举报
回复
lz数据结构还没学好。。
Learn-anything 2010-06-29
  • 打赏
  • 举报
回复
vector的插入效率没有list 好,用list吧
太乙 2010-06-29
  • 打赏
  • 举报
回复
map 是一个关联容器,插入一个元素,位置是固定的,而且只能有一个符合的位置!
lz想要的那种效果,可以试试vector之类的

64,439

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧