有关于关键字匹配的算法,求解!!!

jsshenao 2014-05-06 08:29:36
现在有这样一个需求,我有一大堆文件名,文件名可能有中文、英文,然后给定一个关键词,找出所有含有该关键词的文件名,用什么算法可以实现?
...全文
148 8 打赏 收藏 转发到动态 举报
写回复
用AI写文章
8 条回复
切换为时间正序
请发表友善的回复…
发表回复
赵4老师 2014-05-06
  • 打赏
  • 举报
回复
仅供参考
#include <iostream>
#include <string>
#include <regex>
using namespace std;
int main() {
    string str("This expression could match from A and beyond. [ expression  express ]");
    string rs = "exp\\w*";  // 正则字符串,exp开始的单词
    cout << str << endl;

    regex expression(rs); // 字符串传递给构造函数,建立正则表达式

// regex_match 判断一个正则表达式(参数 e)是否匹配整个字符序列 str. 它主要用于验证文本。
// 注意,这个正则表达式必须匹配被分析串的全部,否则函数返回 false.
// 如果整个序列被成功匹配,regex_match 返回 True.
    bool ret = regex_match(str, expression);
    if (ret)
        cout << "可以匹配整个文本" << endl;
    else
        cout << "不能匹配整个文本" << endl;

// regex_search 类似于 regex_match, 但它不要求整个字符序列完全匹配。
// 你可以用 regex_search 来查找输入中的一个子序列,该子序列匹配正则表达式 e.
    ret = regex_search(str, expression);
    if (ret)
        cout << "能够搜索到 " << rs << endl;
    else
        cout << "不能搜索" << endl;

// regex_replace 在整个字符序列中查找正则表达式e的所有匹配。
// 这个算法每次成功匹配后,就根据参数fmt对匹配字符串进行格式化。
// 缺省情况下,不匹配的文本不会被修改,即文本会被输出但没有改变。

    str = regex_replace(str, expression, string("表达式"));
// VC2010或者TR1注意:这里第三个参数要用string()转换
// http://www.johndcook.com/cpp_regex.html
// started with C++ TR1 regular expressions
    cout << str << endl;
    return 0;
}
//This expression could match from A and beyond. [ expression  express ]
//不能匹配整个文本
//能够搜索到 exp\w*
//This 表达式 could match from A and beyond. [ 表达式  表达式 ]
带汉字需要使用wregex
buyong 2014-05-06
  • 打赏
  • 举报
回复
全文检索,建索引
xengine-qyt 2014-05-06
  • 打赏
  • 举报
回复
首先得到文件名,然后匹配关键字 没有成功就继续下一个文件名。每次得到文件名可以用strstr,文件名一般不会很复杂
tbwork 2014-05-06
  • 打赏
  • 举报
回复
INDEX 啊 index
xiaohuh421 2014-05-06
  • 打赏
  • 举报
回复
如果不遍历, 那就需要使用windos的文件索引系统来查找, 速度也会更快. 总之你需要取得所有文件名, 才有可能判断关键字.
TheNewIpad 2014-05-06
  • 打赏
  • 举报
回复
引用 2 楼 jsshenao 的回复:
[quote=引用 1 楼 xiaohuh421 的回复:] 文件遍历, FindFirstFile 系列函数 然后判断文件名中是否有关键词. strstr 系列函数
如果遍历的话,我也不发帖提问了[/quote] 首先遍历是必须的。 其次,strstr 接口是最笨的。
jsshenao 2014-05-06
  • 打赏
  • 举报
回复
引用 1 楼 xiaohuh421 的回复:
文件遍历, FindFirstFile 系列函数 然后判断文件名中是否有关键词. strstr 系列函数
如果遍历的话,我也不发帖提问了
xiaohuh421 2014-05-06
  • 打赏
  • 举报
回复
文件遍历, FindFirstFile 系列函数 然后判断文件名中是否有关键词. strstr 系列函数

65,208

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧