一个题

https://ac.nowcoder.com/acm/contest/9925/M

题意不想写了,太神奇了,比赛的时候读错了题,害的队伍没打上铁。呜呜呜呜。

#include<bits/stdc++.h>
#include<unordered_set>

using namespace std;
const int maxn=103;
string ignored[maxn];
void solve()
{
    
    
	int n,m;
	cin>>n>>m;
	unordered_set<string> fina,n_ignore;
	for(int i=0;i<n;i++)
	{
    
    
		cin>>ignored[i];
	}
	for(int i=0;i<m;i++)
	{
    
    
		string s;
		cin>>s;
		for(int j=0;j<s.length();j++)
		{
    
    
			if(s[j]=='/')
			{
    
    
				n_ignore.insert(s.substr(0,j+1));
			}
		}
		n_ignore.insert(s);
	}
	for(int i=0;i<n;i++)
	{
    
    
		bool flag=false;
		for(int j=0;j<ignored[i].length()&&!flag;j++)
		{
    
    
			if(ignored[i][j]=='/')
			{
    
    
				string s=ignored[i].substr(0,j+1);
				if(fina.count(s)==1)
				{
    
    
					flag=true;
					break;
				}
				else if(n_ignore.count(s)==0)
				{
    
    
					fina.insert(s);
					flag=true;
					break;
				}
			}
		}
		if(!flag)
		{
    
    
			fina.insert(ignored[i]);
		}
	}
	cout<<fina.size()<<endl;
}

int main()
{
    
    
	ios::sync_with_stdio(false);

	int t;
	cin>>t;
	while(t--)
	{
    
    
		solve();
	}
}

借鉴的别人的思路,人家是真强,我是真菜,垃圾垃圾。。

猜你喜欢

转载自blog.csdn.net/qq_46264636/article/details/111702800