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; }