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();
}
}
借鉴的别人的思路,人家是真强,我是真菜,垃圾垃圾。。