题解 | #字符串匹配#

字符串匹配

https://www.nowcoder.com/practice/fbdc522ef958455687654b38a4ca01e0

#include<bits/stdc++.h>
using namespace std;
void toLower(string &s) {
	for (int i = 0; i < s.size(); i++) {
		s[i] = tolower(s[i]);
	}
	return;
}
bool match(string s, string m) {
	toLower(s);
	toLower(m);
	int front = 0, back = 0;
	int ps = -1, pm = -1;
	int len = s.size();
	while (ps < len) {
		front = m.find('[', pm+1);
		back = m.find(']', pm+2);
		string s1, s2;
		if (front != string::npos) {
			s1 = m.substr(pm+1, front - pm -1);
			s2 = s.substr(ps+1, s1.size());
			if (s1 != s2) {
				break;
			}
			ps += s1.size();
			pm += s1.size();
			s1 = m.substr(front + 1, back - front - 1);
			if (s1.find(s[ps+1]) == string::npos) {
				break;
			}
			ps++;
			pm = back;
		} else {
			s1 = m.substr(pm+1);
			s2 = s.substr(ps+1, s1.size());
			if (s1 != s2) {
				break;
			}
			ps = s.size();
		}
	}
	if (ps < len) {
		return false;
	} else {
		return true;
	}
}
int main() {
	int n;
	string input, m;
	vector<string> words;
	while (cin >> n) {
		for (int i = 0; i < n; i++) {
			cin >> input;
			words.push_back(input);
		}
		cin >> m;
		for (int i = 0; i < n; i++) {
			if (match(words[i], m)) {
				printf("%d %s\n", i + 1, words[i].c_str());
			}
		}
	}
}

全部评论

相关推荐

不愿透露姓名的神秘牛友
07-07 12:04
毕业生招你惹你了,问一个发薪日来一句别看网上乱七八糟的你看哪个工作没有固定发薪日扭头就取消了面试就问了一句公司都是这个态度吗还搞上人身攻击了...
程序员小白条:呃呃呃,都还没面试,我都不会问这么细,何况通不通过,去不去都另说,你没实力和学历的话,在外面就这样,说实话没直接已读不回就不错了,浪费时间基本上
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
07-09 16:15
我应届生,去年10月份开始在这家公司实习,到今年10月份正好一年想(实习+试用期),在想要不要提前9月份就离职,这样好找工作些,但又差一个月满一年,又怕10月份国庆回来离职,容易错过了下半年的金九银十,到年底容易gap到年后
小破站_程序员YT:说这家公司不好吧,你干了快一年 说这家公司好吧,你刚毕业就想跑路说你不懂行情吧,你怕错过金九银十说 你懂行情吧,校招阶段在实习,毕业社招想换工作 哥们,我该怎么劝你留下来呢
应届生,你找到工作了吗
点赞 评论 收藏
分享
程序员小白条:你是沟通了900个,不是投了900份简历,你能投900份,意味着对面都要回复你900次,你早就找到实习了,没亮点就是这样的,别局限地区,时间投的也要早,现在都要7月了
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务