草庐IT

regex_search

全部标签

c++ - boost::regex 和 std::regex 之间的不一致

这个问题在这里已经有了答案:关闭10年前。PossibleDuplicate:Nomatcheswithc++11regex我之前使用boost::regex来处理一些东西,而对于一些我想使用std::regex的新东西,直到我注意到以下不一致-所以问题哪个是正确的?#include#include#include#includevoidtest(std::stringprefix,std::stringstr){std::stringpat=prefix+"\\.\\*.*?";std::cout对我来说(gcc4.7.2,-std=c++11,boost:1.51),我看到了以下内

c++ - 如何在 cpp 中使用 std::regex_replace() 函数查找和替换

我正在做一个项目,我需要找到以$开头并以>$结尾的单词,并将其替换为存储在变量中的单词。例子stringa="hello";stringb="Fellow$$,fullof$$people"std::cout$)\\b",a);//shouldprint"Fellowhello,fullofhellopeople"但似乎这是不可能直接实现的。我该如何解决这个问题? 最佳答案 除了两点,你的代码没有问题:正则表达式-你没有转义$这意味着字符串结束,\b$前后的单词边界这需要一个单词字符出现在$旁边符号。regex_replace没有签

C++ regex_match 不工作

这是我的部分代码boolCSettings::bParseLine(constchar*input){//_asmINT3std::stringline(input);std::size_tposition=std::string::npos,comment;regexcvarPattern("\\.([a-zA-Z_]+)");regexparentPattern("^([a-zA-Z0-9_]+)\\.");regexcvarValue("\\.[a-zA-Z0-9_]+[]*=[]*(\\d+\\.*\\d*)");std::cmatchmatchedParent,matched

c++ - 为什么我的 Boost.Regex 搜索只报告一次匹配迭代?

我试图找出一个字符串中有多少个正则表达式匹配项。我正在使用迭代器来迭代匹配项,并使用整数来记录有多少匹配项。longintbefore=GetTickCount();stringtext;boost::regexre("^(\\d{5})\\s(\\d{8})\\s(.*)\\s(.*)\\s(.*)\\s(\\d{8})\\s(.{1})$");char*buffer;longlength;longcount;ifstreamf;f.open("c:\\temp\\test.txt",ios::in|ios::ate);length=f.tellg();f.seekg(0,ios::

Lepton Search :不到 500 行代码构建对话式搜索引擎|开源|可商用

最近前阿里巴巴副总裁贾扬清在Twitter上公布了LeptonSearch的开源项目链接,ApacheLicense授权,任何人、任何公司都可以自由使用开源代码。大家可以阅读一下源码,非常简洁,核心部分用了500行Python就实现了一个类似Perplexity的生成式搜索引擎。产品特性LeptonSearch拥有一系列引人注目的产品特性,使其在众多搜索引擎中脱颖而出:[1].内置支持大语言模型(LLM):LeptonSearch深度集成了大型语言模型,这意味着它能够利用这些先进的AI技术来理解和处理复杂的查询,为用户提供更加准确和深入的答案。[2]内置搜索引擎支持:LeptonSearch不

c++ - "Search words/strings in Matrix of Char"算法的复杂度

我的任务是从列表中搜索字母(20×20)单词(5)的网格。隐藏在网格中的任何单词总是以锯齿形段的形式出现,其长度可能只有2或3。锯齿形段只能从左到右或从下到上。所需的复杂度等于网格中字母数与列表中字母数的乘积。对于网格:••••••••••••••••••••••••••••ate•••••x••••••••••er•••••••e•••••••••it••••••••v•••••••ell••••••a••f••••••at••••e••••••rbg••••s•••••••ga•••••••和单词列表{"forward","iterate","phone","satellite"}

c++ - 为什么 regex_match 抛出 "complexity exception"?

我正在尝试测试(使用boost::regex)文件中的一行是否仅包含由空格分隔的数字条目。我遇到了一个我不明白的异常(见下文)。如果有人能解释为什么抛出它,那就太好了。也许我在这里以定义模式的方式做了一些愚蠢的事情?这是代码://regex_test.cpp#include#include#includeusingnamespacestd;usingnamespaceboost;intmain(){//Mybasicpatterntotestforasinglenumericexpressionconststringnumeric_value_pattern="(?:-|\\+)?[[

【C++】STL 算法 - 查找算法 ( 查找两个相邻重复元素 - adjacent_find 函数 | 有序容器中通过二分法查找指定元素 - binary_search 函数 )

文章目录一、查找两个相邻重复元素-adjacent_find函数1、函数原型分析2、代码示例二、有序容器中通过二分法查找指定元素-binary_search函数1、函数原型分析2、二分查找时间复杂度分析3、代码示例一、查找两个相邻重复元素-adjacent_find函数1、函数原型分析在C++语言的标准模板库(STL,STLStandardTemplateLibrary)中,提供了adjacent_find算法函数用于在容器中查找两个相邻的重复元素;如果找到两个相邻的重复元素,则返回指向这对元素的第一个元素的迭代器;如果没有找到两个相邻的重复元素,则返回指向序列末尾的迭代器;adjacent_

c++ - 为什么 Boost.Regex 不能在一个字符串中找到多个匹配项?

我正在编写一个小的命令行程序,它要求用户以ax^2+bx^1+cx^0的形式提供多项式。我稍后会解析数据,但现在我只是想看看我是否可以将多项式与正则表达式匹配(\+|-|^)(\d*)x\^([0-9*]*)我的问题是,它不匹配用户输入的多项式中的多个项,除非我将其更改为((\+|-|^)(\d*)x\^([0-9*]*))*(不同之处在于整个表达式被分组并且末尾有一个星号)。如果我键入诸如“4x^2”而不是“4x^2+3x^1+2x^0”之类的内容,则第一个表达式有效,因为它不多次检查。我的问题是,为什么Boost.Regex的regex_match()不能在同一个字符串中找到多个匹

c++ - STL 中的 Binary_search set over set 的成员函数 find?

为什么我们有上述两种方式来搜索集合中的元素?也可以使用查找算法来查找列表或vector中的元素,但是这些提供成员函数以及成员函数预期比通用算法更快的危害是什么?为什么我们需要删除算法并创建所有关于删除删除的戏剧,其中删除只会移动元素然后使用删除删除实际元素..就像STL列表提供了一个成员函数删除为什么其他容器不能只是提供删除功能并完成它? 最佳答案 Binary_searchinSTLsetoverset'smemberfunctionfind?Whydowehave2wayslikeabovetosearchforanelemen