算法合集之《对块状链表点研究》.docVIP

  1. 1、本文档共11页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
算法合集之《对块状链表点研究》

对块状链表的一点研究 山西大学附中 苏煜 【摘要】 本文主要介绍了块状链表的概念,如何扩展块状链表,讨论了块状链表的性能以及在信息学竞赛中应用块状链表的利与弊,最后简要介绍了块状链表思想在实际生活中的应用。 【关键词】 块状链表 分块大小 性能 块状链表的扩展 模拟 骗分 一、什么是块状链表 我们先从题目入手,看看什么是块状链表: NOI2003 editor 【题目大意】 一些定义: 文本:由0个或多个ASCII码在闭区间[32, 126]内的字符(即空格和可见字符)构成的序列。 光标:在一段文本中用于指示位置的标记,可以位于文本首部,文本尾部或文本的某两个字符之间。 文本编辑器:为一个包含一段文本和该文本中的一个光标的,并可以对其进行如下六条操作的程序。如果这段文本为空,我们就说这个文本编辑器是空的。 操作名称 输入文件中的格式 功能 MOVE(k) Move k 将光标移动到第k个字符之后,如果k=0,将光标移到文本开头 INSERT(n, s) Insert n( S 在光标处插入长度为n的字符串s,光标位置不变,n ( 1 DELETE(n) Delete n 删除光标后的n个字符,光标位置不变,n ( 1 GET(n) Get n 输出光标后的n个字符,光标位置不变,n ( 1 PREV() Prev 光标前移一个字符 NEXT() Next 光标后移一个字符 比如一个空的文本编辑器依次执行操作INSERT(13, “Balanced tree”),MOVE(2),DELETE(5),NEXT(),INSERT(7, “ editor”),MOVE(0),GET(16)后,会输出“Bad editor tree”。 你的任务是: 建立一个空的文本编辑器。 从输入文件中读入一些操作并执行。 对所有执行过的GET操作,将指定的内容写入输出文件。 【数据范围】 MOVE操作不超过50000个,INSERT和DELETE操作的总个数不超过4000,PREV和NEXT操作的总个数不超过200000。 所有INSERT插入的字符数之和不超过2M(1M=1024*1024),正确的输出文件长度不超过3M字节。 DELETE操作和GET操作执行时光标后必然有足够的字符。MOVE、PREV、NEXT操作必然不会试图把光标移动到非法位置。 输入文件没有错误。 首先分析题目: 这道题的命令其实只有两类:1.定位;2.添加或删除。 这两类操作也正是两种常见顺序表实现方式的主要区别: 数组 链表 定位 O(1) O(N) 添加或删除 O(N) O(1) 因为单个操作O(N)复杂度的存在,无论我们用哪一种方法,都不可能AC这个题。但是如果我们将这两种方法结合起来,比如在整体上用链表,具体每一个链表节点改为一个大小适当(比如1000、1500)的数组,那么就可以“优势互补”,得到两种操作更加平衡的数据结构,也就是所谓的“块状链表”。 再回到题目,如果用一个整数记录当前位置,那么我们需要一个支持以下操作的数据结构: 1、Insert在指定位置添加指定长度信息; 2、Erase从指定位置开始删除指定长度的信息; 3、Get得到指定位置开始指定长度的信息。 具体实现很简单: 首先我们实现两个内部基本操作: 定位:从第一个分块开始向后直到找到指定位置所在的分块和他在分块内的位置。 分裂:将指定分块从指定位置分裂成为两个分块。 接下来实现外部基本操作: 1、Insert:找到指定位置,分裂块,添加新块直到添加完成。 2、Erase:找到起始位置,分裂首尾块,删掉中间的所有节点。 3、Get:找到指定位置,向后扫描直到找完所需数目。 还有一个问题:频繁的分裂操作可能会导致很多连续的块实际储存的数据都很少,大大降低了块状链表的效率,我们可以在每次操作后把过于小的连续分块合并起来。 这样就满足了题目的所有要求,同时也完成了一个最基本的块状链表。 二、块状链表的简单应用 可以感觉到,块状链表其实是对普通模拟操作的一种优化,它将两种并不优秀的方法结合起来,得到了一个比较实用的数据结构。利用它的这种性质,对有些题目,我们可以“强行”模拟地做: Northeastern Europe 2003, Northern Subregion, KeyInsertion 【题目大意】 N(1 = N = 131 072)个士兵在进行队列训练,从左至右有M(1 = M = 131 072)个位置。每次将军可以下达一个命令,表示为Goto(L,S)。 若队列L位置上为空,那么士兵S站在L上。队列L位置上有士兵K,那么士兵S站在L上,执行Goo(L+1,K): 想到“第x个空位置”和这个题的运作方式很类似:某一个元素的变化会使得它后面的一串元素发生连锁反

文档评论(0)

panguoxiang + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档