题解 | #字符串匹配#

字符串匹配

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

#include<stdio.h>
#include<string>
#include<iostream>
#include<vector>
using namespace std;

bool find(vector<char>v,char ch){
	for(int i=0;i<v.size();i++){
		if(v[i]==ch) return true;
	}
	return false;
}

bool compare(string a,string b){
	if(a==b) return true;
	else return false;
}

int main(){
	int n;
	cin>>n;
	getchar();
	//一个是记录转化为小写的  一个是原来的这是因为要输出原来的样子又因为没有改变顺序所以可以直接按原下标访问 
	vector<string>v;
	vector<string>v2;
	while(n--) {
		string s;
		getline(cin,s);
		v2.push_back(s);
		for(int i=0;i<s.size();i++){
			if(isalpha(s[i])) s[i]=tolower(s[i]);
		}
		v.push_back(s);
	}
	string str;
	getline(cin,str);
	for(int i=0;i<str.size();i++){
		if(isalpha(str[i])) str[i]=tolower(str[i]);
	}
	vector<char>vs;
	int flag=0;
	int start=0,end=0;
	for(int i=0;i<str.size();i++){
		if(flag&&str[i]!=']') vs.push_back(str[i]);
		if(str[i]=='[') {flag=1;start = i;}
		else if(str[i]==']') {end=i;flag=0;}
	}
	//双指针 
	//相等时同时++ 
	//不相等时 1)且str不为[说明不匹配直接返回
	//2)str为 [  就一直++并且找到是否有匹配的直到为 ]  有匹配则令flag=1 
	//当flag!=1说明没有匹配,要结束while否则说明有匹配需要i++继续比较下一个
	//while循环结束时,当i j均指向末尾时说明匹配成功,输出否则不输出	 
	for(int x=0;x<v.size();x++){
		int i=0,j=0;
		string t=v[x];
		int flag=0;
		while(i<t.size()&&j<str.size()){
			if(t[i]==str[j]) {i++;j++;}
			else if(t[i]!=str[j]&&str[j]!='[') break;
			else if(t[i]!=str[j]&&str[j]=='['){
				j++;
				while(str[j]!=']'){
					if(t[i]==str[j]) flag=1;
					j++;
				}
				j++;
				if(flag!=1) break;
				else i++;
			}
		}
		if(i==t.size()&&j==str.size()) cout<<x+1<<' '<<v2[x]<<endl;
	}
}

全部评论

相关推荐

暑期是进不了大厂了想问问前端友友们&nbsp;,后面应该如何沉淀自己,我想秋招再冲一下尤其是八股,应该抓哪一块是重点,理解到什么程度呢,要学到什么深度才能抗住拷打。还有场景题如何去准备。期待友友们的解答。
命烈焰带我飞走:找个中厂小厂先看看吧,去了熟悉熟悉项目,简历上扒点东西,之后刷刷sobb上百度美团快手的日常实习,流程都比较快轮次也少,别给自己太大压力,一步一步来,先不用想着暑期,转正,秋招那些事情,另外如果可能的话可以关注下面试时候的形象,穿搭,环境这些,其实实习主要就是看个眼缘,看着好看声音好听其实加分不少..八股这些不要死记硬背,挨个拿去问问chatgpt,这个东西做出来是为了解决什么问题,有啥效果,自己有想法有个模糊的概念就可以了,人家也知道你是学生,实习生没有什么kpi,放你去面都是希望能把你招进去的,场景题算法题没做过你可以边试着写边跟面试官说你的想法思路,也可以直说没见过让他们给你提示,反正最后都是与或非顺序分支循环存取值那套。总之建议是别为了秋招..出去旅旅游放松放松,少投几家少背八股多写写代码
点赞 评论 收藏
分享
04-28 19:31
门头沟学院 Java
真烦好烦真烦:可恶的二手车贩子,居然对我们门头沟学院的人这么没礼貌
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务