自组织线性表

上传人:M****1 文档编号:558620086 上传时间:2022-11-23 格式:DOC 页数:6 大小:175.50KB
返回 下载 相关 举报
自组织线性表_第1页
第1页 / 共6页
自组织线性表_第2页
第2页 / 共6页
自组织线性表_第3页
第3页 / 共6页
自组织线性表_第4页
第4页 / 共6页
自组织线性表_第5页
第5页 / 共6页
点击查看更多>>
资源描述

《自组织线性表》由会员分享,可在线阅读,更多相关《自组织线性表(6页珍藏版)》请在金锄头文库上搜索。

1、题目:自组织线性表 背景自组织线性表根据估算的访问频率排列记录,先放置请求频率最高的记录,接下来是请求频率次高的记录,依此类推。自组织线性表根据实际的记录访问模式在线性表中修改记录顺序。自组织线性表使用启发式规则决定如何重新排列线性表。转置方法的基本原理是,在一次查找过程中,一旦找到一个记录,则将它与前一个位置的记录交换位置。这样,随着时间的推移,经常访问的记录将移动到线性表的前端,而曾经频繁使用但以后不再访问的记录将逐渐退至线性表的后面。尽管一般情况下自组织线性表的效率可能没有查找数和已排序的线性表那么好,但它也有自身的优势。它可以不必对线性表进行排序,新记录的插入代价很小;同时也比查找树更

2、容易实现,且无需额外的存储空间。问题描述 用转置法实现一个自组织线性表,保存一组汉字用于查询。基本要求 (1) 从文件中读入一组汉字集合,用自组织线性表保存。(2) 在查询时,采用转置法调整自组织线性表的内容。(3) 从文件中依次读入需查询的汉字,把查询结果保存在文件中(如找到,返回比较的次数,如果没有找到,返回比较的次数) 实验分析:题目要求用转置方法实现自组织线性表,也就是把找到的记录与它在线性表中的前一条记录交换位置,随着时间的推移把最常用的记录移动到线性表的前面。函数void transpose(char a2,int i,int j)实现字符串的交换位置。int search(cha

3、r a2,int size,char c2)函数用于查找是否有相应的字符,在自组织线性表中。实验代码:#includeusing namespace std;bool flag;void transpose(char a2,int i,int j); /转置函数的声明int search(char a2,int size,char c2);/search函数的声明int main() int i,m,n,num; static char a2002,b2002,c2; cina0;for(i=0;i+)if(ai0=0)break; m=i; cinb0;for(i=0;i+) if(bi0=

4、0)break; n=i; for(i=0;in;i+) num=search(a,m,bi); c0=bi0; c1=bi1; if(flag) cout查找c成功,查找次数为:numendl; else cout查找c失败,查找次数为:numendl; system(pause); return 0; void transpose(char a2,int i,int j) /转置函数的定义 char temp=ai0; ai0=aj0; aj0=temp; temp=ai1; ai1=aj1; aj1=temp; int search(char a2,int size,char c2) /查找字符串函数 flag=0; int i; for( i=0;i0) transpose(a,i,i-1); return i+1; else return size; 实验结果:

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 建筑/环境 > 施工组织

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号