购物清单

当你去消费时,你会在一个很长的货架上找你需要的东西。由于你只记得部分的关键词,这样就会有很多备用物品供你去选择。现在给出所有的商品名,和你记得的关键字,设计一个程序找出拥有这些关键字的产品的个数。

Input

只有一个测试用例,首先输入一个正整数P(1 ≤ P ≤10000),代表了所有产品的总数,接下来是P行字符串(军事小写,长度不超过20个字符)。然后输入一个正整数Q(1 ≤ Q ≤100000),Q代表了记得的关键字符串的个数,接下来是Q行关键字字符串。

Output

针对每一个字符串输出一个含有该字符串的商品名字的总个数。

Sample Input
20
ad
ae
af
ag
ah
ai
aj
ak
al
ads
add
ade
adf
adg
adh
adi
adj
adk
adl
aes
5
b
a
d
ad
s
Sample Output
0
20
11
11
2

#include<iostream>
#include<cstring>
using namespace std;
char a[1000][20];
int n,m;
void   f( )
{
    char b[20];
    cin>>b;
    int i,j,k,count=0;
    int len2=strlen(b);
    for(i=0;i<n;i++)
    { 
       int len1=strlen(a[i]);
       for(j=0;j<len1;j++)
       {
              k=0;
          while(k<len2&&b[k]==a[i][j+k])
              k++;
          if(k==len2)
          {count++;break;}
       }
      
    }
    cout<<count<<endl;
}
int main()
{
     cin>>n;
     for(int i=0;i<n;i++)
         cin>>a[i];
     cin>>m;
     for(int i=0;i<m;i++)
         f();

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值