C++使用STL中的map实现图书管理系统模糊查询
1. 思路
字符串实现模糊查询。
原理是将一个字符串根据一定的步长将其分割并且排列组合成若干个子串,并且将这些子串作为map的key,这样可以做到输入一部分字符就可以查询出内容来。
例如: “《算法设计与分析》这本书,可以按照步长为1将其拆分成:1. 算,算法,算法设,算法设计.....算法设计与分析。 2. 法,法设.....法设计与分析。 .................................................. 6. 分,分析 7. 析其中因为类似于“法算”, “计设法”,这些排列组合是无意义的字符串所以不与录入。
2. 数据结构
#define hashMap unordered_map // 索引map
#define uint unsigned int
set<uint> // 向量的下标集合
string wholeString // 要拆分的整个原字符串
uint index // 新加入的一条记录在向量中的下标
3. 算法一
查找时间O(1), 直接用中括号取值,占用内存空间多
/**
*
* @param hashMap< string, set<uint> > &mp, const string &wholeString, uint index
* @return void
* @author ginga
* @description: 根据字符串wholeString创建它的所有从左到右顺序的子串, 并将其作为key, index作为set的value, 最后插入mp中
* @date 8/5/2022 上午10:51
*/
static void createSubStringMap(hashMap< string, set<uint> > &mp, const string &wholeString, uint index) {
for (uint i = 0, len = wholeString.size(); i < len; i+=2) {
for (uint j = i; j < len; j+=2) { // 因为中文字符占两位
string subString = wholeString.substr(i, j-i+2);
mp[subString].insert(index);
}
}
}
算法二
使用multimap的equal_range()函数查找,有下标重复的隐患,可以将取的值放到set里去重。
static void createSubStringMap(multimap<string, uint> &mp, const string &wholeString, uint index) {
for(uint i = 0, len = wholeString.size(); i < len; i+=2)
for(uint j = i; j < len; j+=2) {
string subString = wholeString.substr(i, j-i+2);
mp.insert(make_pair<string, uint>(subString, index));
}
}
本文介绍如何使用C++的STL库unordered_map和set数据结构,配合字符串操作,实现在图书管理系统中进行模糊查询,通过创建子串映射快速定位相关书籍。两种算法对比,一种提供O(1)查找,另一种借助multimap进行高效查找并去重。
2917

被折叠的 条评论
为什么被折叠?



