2008北航:字符串匹配
- 题目描述:
-
读入数据string[ ],然后读入一个短字符串。要求查找string[ ]中和短字符串的所有匹配,输出行号、匹配字符串。匹配时不区分大小写,并且可以有一个用中括号表示的模式匹配。如“aa[123]bb”,就是说aa1bb、aa2bb、aa3bb都算匹配。
- 输入:
-
输入有多组数据。
每组数据第一行输入n(1<=n<=1000),从第二行开始输入n个字符串(不含空格),接下来输入一个匹配字符串。
- 输出:
-
输出匹配到的字符串的行号和该字符串(匹配时不区分大小写)。
- 样例输入:
-
4 Aab a2B ab ABB a[a2b]b
- 样例输出:
-
1 Aab 2 a2B 4 ABB
注意是从n的字符串向匹配字符串比较。#include <iostream> #include <string> using namespace std; const int MAXN=1005; string src[MAXN]; string buf[MAXN]; string T; int n; int main() { while(cin>>n) { for(int i=0;i<n;i++) { cin>>src[i]; buf[i]=src[i]; for(int j=0;j<src[i].size();j++) { if('A'<=buf[i][j]&&buf[i][j]<='Z') buf[i][j]+=32; } } cin>>T; for(int i=0;i<T.size();i++) { if('A'<=T[i]&&T[i]<='Z') T[i]+=32; } int pos1=T.find("["); if(pos1==string::npos) { for(int i=0;i<n;i++) { if(T==buf[i]) cout<<i+1<<" "<<src[i]<<endl; } } else { int pos2=T.find("]"); string pre=T.substr(0,pos1); string post=T.substr(pos2+1); for(int i=0;i<n;i++) { for(int j=pos1+1;j<pos2;j++) { string sub=""; char t=T[j]; sub+=pre; sub+=t; sub+=post; if(buf[i]==sub) { cout<<i+1<<" "<<src[i]<<endl; break; } } } } } return 0; }
【推荐】还在用 ECharts 开发大屏?试试这款永久免费的开源 BI 工具!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 从问题排查到源码分析:ActiveMQ消费端频繁日志刷屏的秘密
· 一次Java后端服务间歇性响应慢的问题排查记录
· dotnet 源代码生成器分析器入门
· ASP.NET Core 模型验证消息的本地化新姿势
· 对象命名为何需要避免'-er'和'-or'后缀
· “你见过凌晨四点的洛杉矶吗?”--《我们为什么要睡觉》
· 编程神器Trae:当我用上后,才知道自己的创造力被低估了多少
· C# 从零开始使用Layui.Wpf库开发WPF客户端
· C#/.NET/.NET Core技术前沿周刊 | 第 31 期(2025年3.17-3.23)
· 开发的设计和重构,为开发效率服务