欢迎来到天天文库
浏览记录
ID:19872988
大小:496.50 KB
页数:156页
时间:2018-10-07
《精品大学课件清华殷人昆数据结构笔记(c版)_1》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库。
1、静态索引结构动态索引结构Trie树散列(Hashing)小结第十章索引与散列静态索引结构示例:有一个存放职工信息的数据表,每一个职工对象有近1k字节的信息,正好占据一个页块的存储空间。当数据对象个数n很大时,如果用无序表形式的静态搜索结构存储,采用顺序搜索,则搜索效率极低。如果采用有序表存储形式的静态搜索结构,则插入新记录进行排序,时间开销也很可观。这时可采用索引方法来实现存储和搜索。线性索引(LinearIndexList)假设内存工作区仅能容纳64k字节的数据,在某一时刻内存最多可容纳64个对
2、象以供搜索。如果对象总数有14400个,不可能把所有对象的数据一次都读入内存。无论是顺序搜索或对分搜索,都需要多次读取外存记录。如果在索引表中每一个索引项占4个字节,每个索引项索引一个职工对象,则14400个索引项需要56.25k字节,在内存中可以容纳所有的索引项。这样只需从外存中把索引表读入内存,经过搜索索引后确定了职工对象的存储地址,再经过1次读取对象操作就可以完成搜索。稠密索引:一个索引项对应数据表中一个对象的索引结构。当对象在外存中按加入顺序存放而不是按关键码有序存放时必须采用稠密索引结构
3、,这时的索引结构叫做索引非顺序结构。稀疏索引:当对象在外存中有序存放时,可以把所有n个对象分为b个子表(块)存放,一个索引项对应数据表中一组对象(子表)。在子表中,所有对象可能按关键码有序地存放,也可能无序地存放。但所有这些子表必须分块有序,后一个子表中所有对象的关键码均大于前一个子表中所有对象的关键码。它们都存放在数据区中。另外建立一个索引表。索引表中每一表目叫做索引项,它记录了子表中最大关键码max_key以及该子表在数据区中的起始位置obj_addr。各个索引项在索引表中的序号与各个子表的块
4、号有一一对应的关系:第i个索引项是第i个子表的索引项,i=0,1,…,n-1。这样的索引结构叫做索引顺序结构。对索引顺序结构进行搜索时,一般分为两级搜索。先在索引表ID中搜索给定值K,确定满足ID[i-1].max_key5、序,只能顺序搜索。索引顺序搜索的搜索成功时的平均搜索长度ASLIndexSeq=ASLIndex+ASLSubList其中,ASLIndex是在索引表中搜索子表位置的平均搜索长度,ASLSubList是在子表内搜索对象位置的搜索成功的平均搜索长度。设把长度为n的表分成均等的b个子表,每个子表s个对象,则b=n/s。又设表中每个对象的搜索概率相等,则每个子表的搜索概率为1/b,子表内各对象的搜索概率为1/s。若对索引表和子表都用顺序搜索,则索引顺序搜索的搜索成功时的平均搜索长度为ASLIndex6、Seq=(b+1)/2+(s+1)/2=(b+s)/2+1索引顺序搜索的平均搜索长度不仅与表中的对象个数n有关,而且与每个子表中的对象个数s有关。在给定n的情况下,s应选择多大?利用数学方法可以导出,当s=时,ASLIndexSeq取极小值+1。这个值比顺序搜索强,但比对分搜索差。但如果子表存放在外存时,还要受到页块大小的制约。若采用对分搜索确定对象所在的子表,则搜索成功时的平均搜索长度为ASLIndexSeq=ASLIndex+ASLSubListlog2(b+1)-1+(s+1)/2log7、2(1+n/s)+s/2倒排表(InvertedIndexList)对包含有大量数据对象的数据表或文件进行搜索时,最常用的是针对对象的主关键码建立索引。主关键码可以唯一地标识该对象。用主关键码建立的索引叫做主索引。主索引的每个索引项给出对象的关键码和对象在表或文件中的存放地址。但在实际应用中有时需要针对其它属性进行搜索。例如,查询如下的职工信息:(1)列出所有教师的名单;(2)已婚的女性职工有哪些人?对象关键码key对象存放地址addr这些信息在数据表或文件中都存在,但都不是关键码,为回答以上问题8、,只能到表或文件中去顺序搜索,搜索效率极低。因此,除主关键码外,可以把一些经常搜索的属性设定为次关键码,并针对每一个作为次关键码的属性,建立次索引。在次索引中,列出该属性的所有取值,并对每一个取值建立有序链表,把所有具有相同属性值的对象按存放地址递增的顺序或按主关键码递增的顺序链接在一起。次索引的索引项由次关键码、链表长度和链表本身等三部分组成。为了回答上述的查询,我们可以分别建立“性别”、“婚否”和“职务”次索引。(1)列出所有教师的名单;(2)已婚的女性职工有哪些人?通过顺序访
5、序,只能顺序搜索。索引顺序搜索的搜索成功时的平均搜索长度ASLIndexSeq=ASLIndex+ASLSubList其中,ASLIndex是在索引表中搜索子表位置的平均搜索长度,ASLSubList是在子表内搜索对象位置的搜索成功的平均搜索长度。设把长度为n的表分成均等的b个子表,每个子表s个对象,则b=n/s。又设表中每个对象的搜索概率相等,则每个子表的搜索概率为1/b,子表内各对象的搜索概率为1/s。若对索引表和子表都用顺序搜索,则索引顺序搜索的搜索成功时的平均搜索长度为ASLIndex
6、Seq=(b+1)/2+(s+1)/2=(b+s)/2+1索引顺序搜索的平均搜索长度不仅与表中的对象个数n有关,而且与每个子表中的对象个数s有关。在给定n的情况下,s应选择多大?利用数学方法可以导出,当s=时,ASLIndexSeq取极小值+1。这个值比顺序搜索强,但比对分搜索差。但如果子表存放在外存时,还要受到页块大小的制约。若采用对分搜索确定对象所在的子表,则搜索成功时的平均搜索长度为ASLIndexSeq=ASLIndex+ASLSubListlog2(b+1)-1+(s+1)/2log
7、2(1+n/s)+s/2倒排表(InvertedIndexList)对包含有大量数据对象的数据表或文件进行搜索时,最常用的是针对对象的主关键码建立索引。主关键码可以唯一地标识该对象。用主关键码建立的索引叫做主索引。主索引的每个索引项给出对象的关键码和对象在表或文件中的存放地址。但在实际应用中有时需要针对其它属性进行搜索。例如,查询如下的职工信息:(1)列出所有教师的名单;(2)已婚的女性职工有哪些人?对象关键码key对象存放地址addr这些信息在数据表或文件中都存在,但都不是关键码,为回答以上问题
8、,只能到表或文件中去顺序搜索,搜索效率极低。因此,除主关键码外,可以把一些经常搜索的属性设定为次关键码,并针对每一个作为次关键码的属性,建立次索引。在次索引中,列出该属性的所有取值,并对每一个取值建立有序链表,把所有具有相同属性值的对象按存放地址递增的顺序或按主关键码递增的顺序链接在一起。次索引的索引项由次关键码、链表长度和链表本身等三部分组成。为了回答上述的查询,我们可以分别建立“性别”、“婚否”和“职务”次索引。(1)列出所有教师的名单;(2)已婚的女性职工有哪些人?通过顺序访
此文档下载收益归作者所有