数据结构与STL_第7章_查找.ppt

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
映射(map) 2 、 数据的删除 //如果要删除1,用迭代器删除 mapint, string::iterator iter; iter = mapStudent.find(1); mapStudent.erase(iter); * * 映射(map) 3、数据的查找 第一种:用count函数来判定关键字是否出现,返回1,元素存在;否则返回1。比如查找关键字1是否存在? int index = mapStudent. count(1); * * 映射(map) 第二种:用find函数来定位数据出现位置,它返回的一个迭代器,当数据出现时,它返回数据所在位置的迭代器,如果map中没有要查找的数据,它返回的迭代器等于end函数返回的迭代器: mapint, char*::iterator iter; iter = mapStudent.find(1); if (iter != mapStudent.end()) cout”Find, the value is ”iter-secondendl; else cout”Do not Find”endl; * * 映射(map) 其他数据的基本操作 返回map元素的个数: mapStudent.size(); 将map清为空集:mapStudent.clear() ; 判断map是否为空:mapStudent.Empty() ; 数据的遍历:比如用数组方式 int nSize = mapStudent.size(); for(int nIndex = 0; nIndex nSize; nIndex++) { coutmapStudent[nIndex]end; } * * 小结 (1)set(集合)——包含经过排序的数据,这些数据的值(value)必须是唯一的。 (2)map(映射)——经过排序的二元组集合,map中的每个元素都是由两个值组成,其中key键值必须是唯一,而另一个值是该元素关联的数值。 (3)multiset(多重集)——和集合(set)相似,其中的值可以重复。 (4)multimap(多重映射)——和映射(map)相似,其中的键值可以有重复。 * * 第七章 查找 学习内容: 1. 概述 2. 线性表的查找技术 3. 树表的查找技术 4. 散列表的查找技术 5. 查找的应用 6. STL中的相关模版类 * 《数据结构与STL》 5. 查找的应用 * 5. 查找的应用 主要内容 1. 文件查找 2. 中文分词技术中的词搜索算法 * * 1. 文件查找 问题 一个文件包含至多10,000,000条数据,每条数据都是一个7位的整数,每个整数至多出现一次,系统只有2MB的内存空间,和无限大的硬盘空间,如何利用利用散列表来实现存储和查找? * * 1. 文件查找 基本思想 利用类似位图的方法来实现散列函数。 例如集合{1,2,3,5,8,13}人存储方式可以是这样的 0 1 1 1 0 1 0 0, 1 0 0 0 0 1 0 0, 0 0 0 0 将代表数字的各个位设置1,其他位全部设置0。 存储空间it(10Mbit = 1.25MB2MB) 当且仅当整数i在该文件中存在,将第i位置1;否则置0。 * * 1. 文件查找 初始化长度为N字符串,全部位置0,这里 N=(最大整数值+1)/一个char所占用的bit数8=1250000 读取文件中一条数据,把相应bit置1,再读下一条数据,直到文件结束 查找时只需按位检测bit是否为1,若待查数据对应bit为1,则查找成功;否则查找失败; * * 1. 文件查找 模块化划分 1)构造一个空的散列表 unsigned char ch[1250000] = {0}; 2)在散列表中插入一个元素 void insert_ele (unsigned char ch[], int elementary); 3)在散列表中查找一个元素 bool search_ele (unsigned char ch[], int elementary) 4)读取文件,并调用函数(2生成散列表 5)读取用户输入,并调用函数(3查找散列表 * * 2. 中文分词技术中的词搜索算法 所谓中文分词,是指将一个汉字序列切分成一个一个单独的词。 中文分词是自然语言处理、文本挖掘等研究领域的基础。 * * 2. 中文分词技术中的词搜索算法 基于字符串匹配的分词方法 它按照一定的策略将待分析的汉字串与一个“充分大的”中文词典中的词条进行匹配,

文档评论(0)

四月 + 关注
实名认证
内容提供者

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

1亿VIP精品文档

相关文档