Loading [MathJax]/jax/output/CommonHTML/config.js
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >关于数据结构的建议

关于数据结构的建议
EN

Stack Overflow用户
提问于 2018-11-13 05:54:24
回答 3查看 149关注 0票数 4

我一直在努力寻找符合以下要求的合适的数据结构:

  1. 这种数据结构的元素被组织成块。这些块的顺序有点不相关,但是块中的元素保持一定的顺序。
  2. 插入次数不多。
  3. 搜索的频率要高得多。
  4. 检索数据结构中元素的索引至关重要。
  5. 一旦搜索了数据结构的元素,数据结构中的下一个或前一个元素应该是容易访问的。

考虑到这一点,我有以下考虑:

  • 链接列表或双链接列表对于需求1、2、4和5可能是最优的,但强制进行线性搜索,这会折衷req。3.
  • 哈希表解决了req问题。但据我所知,这在req方面是个问题。5因为在使用散列时,会失去对数据结构中元素的位置的控制。

开发一个与我需要的顺序相匹配的散列函数可能很棘手,因为输入键可以是部分随机的。

我正在考虑的一个可能的解决方案(在C中)是保留一个指向保持插入顺序(或我需要的顺序)的元素的指针数组,然后是第二个指针数组,它使用哈希函数对元素进行排序。第一个数组可用于快速访问元素和查找邻居,而第二个数组可用于快速搜索元素。但不知何故,我给人的印象是,事情过于复杂,我不想重新发明轮子。

你认为如何?任何建议都将不胜感激。

非常感谢

EN

回答 3

Stack Overflow用户

发布于 2018-11-13 06:27:01

在这种情况下,数组可能是最好的数据结构。

插入数组需要搜索新元素的正确插槽,然后使用memmove将所有较大的元素向右移动。如果插入频繁,这可能会很昂贵,但如果不像您所说的那样频繁,那么它就不会是一个问题。然后通过索引和O(1)搜索进行O(log n)检索。

维护指向实际数据的指针数组是一个很好的步骤,因为这意味着在插入新元素时只复制指针而不是完整的数据结构。

因此,您有一个数组,该数组包含仅附加到的数据,以及用于每个插入的指针数组(即找到正确的位置和移位)。

票数 2
EN

Stack Overflow用户

发布于 2018-11-13 06:12:57

搜索树呢?这是一个很好的适合您的所有要求,除了4。

为了处理这个要求,您可以为每个节点维护一个额外的计数器。此计数器将记录节点下方子树中的节点数。

添加计数器将允许在执行搜索操作时查找目标节点的索引(有关示例如何,请参见here )。这将使插入操作更加复杂,因为插入节点之后,您还需要更新所有祖先树中的计数器,但是既然您说不会有很多插入,就不会有问题。

票数 0
EN

Stack Overflow用户

发布于 2018-11-13 06:32:49

可能是一个“链式哈希表”,其中哈希表中的每个索引都是一个双链接列表。在您的示例中,我想每个“块”都将由这样一个双链接列表来表示。

这样可以快速搜索块,但对块中的单个元素的搜索相对较慢。块内的项数很重要。但是,您将立即得到下一个/上一个项目,并且从那里遍历列表也会很快。链接列表也可以实现为数组,这比单个节点的堆分配对数据缓存内存更友好。

或者,您也可以使用类似的哈希表,但是对每个索引使用二进制搜索树。你会得到快速的搜索,它将与大量的数据很好地扩展。在检索下一个/上一个项目时,它会稍微慢一些,因为您必须检查是否存在左/右叶,否则检查父节点。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/53282597

复制
相关文章
firebase怎么用_firebase是什么
发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/168361.html原文链接:https://javaforall.cn
全栈程序员站长
2022/09/20
4.2K0
firebase怎么用_firebase是什么
CDN刷新目录不生效?
选择 “刷新变更资源” 模式,当用户访问匹配目录下资源时,会回源获取资源的 Last-Modify 信息,若与当前缓存资源一致,则直接返回已缓存资源,若不一致,回源拉取资源并重新缓存;
任雯霄
2020/12/30
6.1K1
Vue 实现前进刷新,后退不刷新的效果
假设列表页为 list.vue,详情页为 detail.vue,这两个都是子组件。
谭光志
2020/09/28
3K0
vue 参数变化页面不刷新
查询参数变化,不刷新 http://localhost:8081/#/detail?id=1 http://localhost:8081/#/detail?id=2 参数变化,不刷新 http://
onety码生
2018/11/21
2.5K0
js – form表单提交不刷新
大家已经发现了, 当我们点击submit提交form表单的时候, 他会刷新一次, 如果不想它刷新的话有下面两种方法:
全栈程序员站长
2022/08/01
14.6K0
RDP你的凭据不工作/RDP密码不刷新
如果你不属于上述的情况,请查看:https://learn.microsoft.com/zh-cn/windows-server/remote/remote-desktop-services/troubleshoot/rdp-error-general-troubleshooting#check-whether-a-group-policy-object-gpo-is-blocking-rdp-on-a-local-computer
阿龙w
2022/12/02
12.7K0
RDP你的凭据不工作/RDP密码不刷新
Laravel7使用Auth进行用户认证
Laravel7 的 laravel/ui 包提供了一种快速方法,可以使用一些简单的命令来支持你进行身份验证所需的所有路由和视图:
Lansonli
2021/10/09
5.8K0
vue强制刷新页面方法_vue页面回退不刷新
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
全栈程序员站长
2022/11/17
5K0
谷歌?新手不推荐 选它就对了
首先第一个好处就是可以登录账号,实现账号登录同步书签,添加书签方便多了,还能扩展组件。
江拥羡橙
2022/11/17
6330
谷歌?新手不推荐 选它就对了
将 Supabase 作为下一个后端服务
对于想快速实现一个产品而言,如果使用传统开发,又要兼顾前端开发,同时又要花费时间构建后端服务。然而有这么一个平台(Baas Backend as a service)后端即服务,能够让开发人员可以专注于前端开发,而无需花费大量时间和精力来构建和维护后端基础设施。
愧怍
2023/03/14
7.8K0
将 Supabase 作为下一个后端服务
nuxt+vue仿微信聊天界面|nuxt.js聊天室
nuxtjs是一个基于vue.js构建的服务端渲染框架。让你的网页也拥有SEO能力。只要是会vue,上手及非常简单了。
andy2018
2020/10/16
3.7K0
nuxt+vue仿微信聊天界面|nuxt.js聊天室
layui打开iframe窗口不刷新的问题
这个问题可能是我工作以来,最死磕不算bug的一个了,晚上熬夜到三点钟,终于找到了解决的办法。
王小婷
2019/04/29
4K0
layui打开iframe窗口不刷新的问题
在nuxt.js项目中对axios进行封装
不管是在服务端还是客户端获取数据都可以使用axios。在实际的开发过程中,每次请求中往往要携带一些自定义的参数或进行一些统一的处理,所以对axios进行封装是必不可少的。那么对于axios封装应该写在那个目录下呢?
用户3258338
2019/09/17
6.3K0
将 Supabase 作为下一个后端服务
对于想快速实现一个产品而言,如果使用传统开发,又要兼顾前端开发,同时又要花费时间构建后端服务。然而有这么一个平台(Baas Backend as a service)后端即服务,能够让开发人员可以专注于前端开发,而无需花费大量时间和精力来构建和维护后端基础设施。
愧怍
2023/02/24
4.7K0
将 Supabase 作为下一个后端服务
Firebase 如何创建登录 Token
Firebase 的 token 可以使用 firebase 命令行工具来进行创建。
HoneyMoose
2021/04/02
2.5K0
Firebase 如何创建登录 Token
JWT 的详细资源
1、laravel firebase/php-jwt token验证
八点半的Bruce、D
2023/02/28
2.9K0
JWT 的详细资源
WPF 的 VisualBrush 只刷新显示的视觉效果,不刷新布局范围
WPF 的 VisualBrush 可以帮助我们在一个控件中显示另一个控件的外观。这是非常妙的功能。
walterlv
2023/10/22
4440
WPF 的 VisualBrush 只刷新显示的视觉效果,不刷新布局范围
Vue 改变数据,页面不刷新的问题
最近在用 element-ui 开发一个网站,使用 table 组件时,发现修改完数据,有时候会延迟一两秒,页面才会发生变化。
谭光志
2020/09/28
3.4K0
点击加载更多

相似问题

如何持久化firebase-auth而不是使用Nuxt刷新?

220

Nuxt.js + nuxt-auth模块刷新jwt

314

Nuxt Auth函数不是反应性的,需要进行硬刷新。

12

Nuxt.js + Auth ( jwt刷新令牌)

25

刷新后FireBase auth签出

11
添加站长 进交流群

领取专属 10元无门槛券

AI混元助手 在线答疑

扫码加入开发者社群
关注 腾讯云开发者公众号

洞察 腾讯核心技术

剖析业界实践案例

扫码关注腾讯云开发者公众号
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文