购物清单

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

输入

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

输出

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

样例输入
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
样例输出
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();

}

 

转载于:https://www.cnblogs.com/Lazy-Cat/p/9838423.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值