高分求助关于1000数量级的排序问题,求指教

whichname 2011-06-19 11:29:14
现有一有序序列A记录数1000左右;
一段时间之后,
1、有超过序列A中最小数的部分数据需要加入,
2、时之前A中也有部分数据因为增大,

所以需要对他们重新进行排序

请各位不吝赐教!!!
谢谢了
...全文
163 11 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
11 条回复
切换为时间正序
请发表友善的回复…
发表回复
whichname 2011-06-21
  • 打赏
  • 举报
回复
[Quote=引用 10 楼 kyotrue 的回复:]
引用 4 楼 whichname 的回复:
引用 3 楼 kyotrue 的回复:
用std::map就行了,采用红黑二叉树,查找、插入、删除都很快,我用来做百万级的队列管理都没问题。

限制是你的索引值不能重复,如果索引变了,就得先删除再重新插入。

对std::map<key, value>:
key确实能做到是唯一的,关键是我要得到值value有序的,另外std::map好象按……
[/Quote]

value可能重复吧
kyotrue 2011-06-20
  • 打赏
  • 举报
回复
[Quote=引用 4 楼 whichname 的回复:]
引用 3 楼 kyotrue 的回复:
用std::map就行了,采用红黑二叉树,查找、插入、删除都很快,我用来做百万级的队列管理都没问题。

限制是你的索引值不能重复,如果索引变了,就得先删除再重新插入。

对std::map<key, value>:
key确实能做到是唯一的,关键是我要得到值value有序的,另外std::map好象按key来排序的吧?
[/Quote]

把你用来排序的value当作key啊
fishion 2011-06-20
  • 打赏
  • 举报
回复
stdlib.h里调用qsort
hztj2005 2011-06-20
  • 打赏
  • 举报
回复
vector 保存数据
sort排序。

或者网上搜QSort代码。
whichname 2011-06-19
  • 打赏
  • 举报
回复
[Quote=引用 5 楼 oyljerry 的回复:]
引用 4 楼 whichname 的回复:
引用 3 楼 kyotrue 的回复:
用std::map就行了,采用红黑二叉树,查找、插入、删除都很快,我用来做百万级的队列管理都没问题。

限制是你的索引值不能重复,如果索引变了,就得先删除再重新插入。

对std::map<key, value>:
key确实能做到是唯一的,关键是我要得到值value有序的,另外std::map好象按……
[/Quote]

能否给说得详细点

还有,
对一1000记录的有序序列,有部分元素变大,同时需要加进部分数据(0 - 200左右吧),所以需要对这1000多个数据进行重新排序,不知道如何处理效率高一点,实现简单一些
oyljerry 2011-06-19
  • 打赏
  • 举报
回复
[Quote=引用 4 楼 whichname 的回复:]
引用 3 楼 kyotrue 的回复:
用std::map就行了,采用红黑二叉树,查找、插入、删除都很快,我用来做百万级的队列管理都没问题。

限制是你的索引值不能重复,如果索引变了,就得先删除再重新插入。

对std::map<key, value>:
key确实能做到是唯一的,关键是我要得到值value有序的,另外std::map好象按key来排序的吧?
[/Quote]
可以自己find来排序。而且可以用两个map,key,value对换
whichname 2011-06-19
  • 打赏
  • 举报
回复
[Quote=引用 3 楼 kyotrue 的回复:]
用std::map就行了,采用红黑二叉树,查找、插入、删除都很快,我用来做百万级的队列管理都没问题。

限制是你的索引值不能重复,如果索引变了,就得先删除再重新插入。
[/Quote]
对std::map<key, value>:
key确实能做到是唯一的,关键是我要得到值value有序的,另外std::map好象按key来排序的吧?
kyotrue 2011-06-19
  • 打赏
  • 举报
回复
用std::map就行了,采用红黑二叉树,查找、插入、删除都很快,我用来做百万级的队列管理都没问题。

限制是你的索引值不能重复,如果索引变了,就得先删除再重新插入。
whichname 2011-06-19
  • 打赏
  • 举报
回复
[Quote=引用 1 楼 wltg2001 的回复:]
1、有超过序列A中最小数的部分数据需要加入,
========
这个直接插前面就是了,如果是用链表存储的话两句就行了,如果是数组的话你得移位。

时之前A中也有部分数据因为增大,
===========
这个没看懂。
[/Quote]

就是即使没有外部的数据加入近来,由于部分数据变化,之前A中有序的1000个记录从而变得无序,需要重新进行排序
wltg2001 2011-06-19
  • 打赏
  • 举报
回复
1、有超过序列A中最小数的部分数据需要加入,
========
这个直接插前面就是了,如果是用链表存储的话两句就行了,如果是数组的话你得移位。

时之前A中也有部分数据因为增大,
===========
这个没看懂。
oyljerry 2011-06-19
  • 打赏
  • 举报
回复
[Quote=引用 6 楼 whichname 的回复:]
引用 5 楼 oyljerry 的回复:
引用 4 楼 whichname 的回复:
引用 3 楼 kyotrue 的回复:
用std::map就行了,采用红黑二叉树,查找、插入、删除都很快,我用来做百万级的队列管理都没问题。

限制是你的索引值不能重复,如果索引变了,就得先删除再重新插入。

对std::map<key, value>:
key确实能做到是唯一的,关键是我要得到值……
[/Quote]
实现sort()函数.

16,548

社区成员

发帖
与我相关
我的任务
社区描述
VC/MFC相关问题讨论
社区管理员
  • 基础类社区
  • AIGC Browser
  • encoderlee
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

        VC/MFC社区版块或许是CSDN最“古老”的版块了,记忆之中,与CSDN的年龄几乎差不多。随着时间的推移,MFC技术渐渐的偏离了开发主流,若干年之后的今天,当我们面对着微软的这个经典之笔,内心充满着敬意,那些曾经的记忆,可以说代表着二十年前曾经的辉煌……
        向经典致敬,或许是老一代程序员内心里面难以释怀的感受。互联网大行其道的今天,我们期待着MFC技术能够恢复其曾经的辉煌,或许这个期待会永远成为一种“梦想”,或许一切皆有可能……
        我们希望这个版块可以很好的适配Web时代,期待更好的互联网技术能够使得MFC技术框架得以重现活力,……

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