C++使用map实现模糊查询

本文介绍如何使用C++的STL库unordered_map和set数据结构,配合字符串操作,实现在图书管理系统中进行模糊查询,通过创建子串映射快速定位相关书籍。两种算法对比,一种提供O(1)查找,另一种借助multimap进行高效查找并去重。

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 中的容器(如 vector 或 map)来存储这些数据项,并使用 lambda 表达式或自定义的比较函数来实现多条件模糊查询。 例如,假设我们有一个 Person 结构体,包含 name,age 和 gender 三个属性,我们可以使用 vector 来存储多个 Person 对象,并使用 lambda 表达式来实现多条件模糊查询。示例代码如下: ```c++ #include <iostream> #include <vector> #include <algorithm> #include <string> using namespace std; struct Person { string name; int age; string gender; }; int main() { vector<Person> people = { {"Alice", 18, "Female"}, {"Bob", 25, "Male"}, {"Charlie", 30, "Male"}, {"David", 20, "Male"}, {"Emily", 22, "Female"} }; // 查询年龄大于 20,性别为 Male 的人 auto query = [](const Person& p) { return p.age > 20 && p.gender == "Male"; }; vector<Person> result; copy_if(people.begin(), people.end(), back_inserter(result), query); for (const auto& p : result) { cout << p.name << " " << p.age << " " << p.gender << endl; } return 0; } ``` 在上面的代码中,我们使用 lambda 表达式来定义查询条件 query,然后使用 std::copy_if 算法和 back_inserter 迭代器将满足条件的 Person 对象插入到 result 容器中,最后输出查询结果。 除了 lambda 表达式,我们还可以使用自定义的比较函数来实现多条件模糊查询。示例代码如下: ```c++ #include <iostream> #include <vector> #include <algorithm> #include <string> using namespace std; struct Person { string name; int age; string gender; }; bool compare(const Person& p1, const Person& p2) { if (p1.age != p2.age) { return p1.age > p2.age; } else if (p1.gender != p2.gender) { return p1.gender < p2.gender; } else { return p1.name < p2.name; } } int main() { vector<Person> people = { {"Alice", 18, "Female"}, {"Bob", 25, "Male"}, {"Charlie", 30, "Male"}, {"David", 20, "Male"}, {"Emily", 22, "Female"} }; // 按照年龄降序、性别升序、姓名升序排序 sort(people.begin(), people.end(), compare); for (const auto& p : people) { cout << p.name << " " << p.age << " " << p.gender << endl; } return 0; } ``` 在上面的代码中,我们使用自定义的 compare 函数来实现多条件模糊查询,该函数按照年龄降序、性别升序、姓名升序排序。最后,我们使用 std::sort 算法将 people 容器中的元素按照 compare 函数定义的顺序排序,并输出排序结果。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值