V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX 提问指南
1oNflow
V2EX  ›  问与答

向必须保证有序的数据里插入新数据,并获取新数据应在的位置,用什么数据结构比较好?

  •  
  •   1oNflow · 2019-09-23 20:52:26 +08:00 · 1079 次点击
    这是一个创建于 1891 天前的主题,其中的信息可能已经有所发展或是发生改变。

    数据都是数值类型,没有特定分布,新数据应在的位置的意思是插入这个数据后,从小到大排它是第几个。

    想到可以用二叉搜索树,但是每次获取位置都要先插入,再从头遍历,效率可能有影响。

    或者用有序链表,但是链表似乎不好存进数据库里。

    想问下这种场景用什么数据结构比较好?

    3 条回复    2019-09-24 00:32:25 +08:00
    xupefei
        1
    xupefei  
       2019-09-23 23:53:16 +08:00
    改一个排序算法,在插入元素时返回最终确定的 index。
    starsriver
        2
    starsriver  
       2019-09-23 23:59:31 +08:00 via Android   ❤️ 1
    既然是纯数值而且往数据库里面搁,那就直接主键有序,没必要用奇奇怪怪的算法。可能有重复的数据那就分统计表和数据表,用统计表的主键做为数据表的索引。
    billlee
        3
    billlee  
       2019-09-24 00:32:25 +08:00   ❤️ 2
    可以在二叉树的节点维护该节点的秩
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   3526 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 25ms · UTC 04:44 · PVG 12:44 · LAX 20:44 · JFK 23:44
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.