标签:str 直接 i+1 pac ++i 存在 highlight char s print
题意:有n群人,每个人有喜欢的汉堡配方;有m家店,给出每家店的每个汉堡的配方,如果存在某个汉堡,其配料表包含某个人喜欢的配方,则这个人喜欢这个汉堡所在的店家。问你对每群人,输出被喜欢的人数最多的店面是哪家。
直接把每家店所能满足的口味表全塞到哈希表里面,暴力枚举统计即可。
这里用了双关键字哈希表,比较巧妙,是绝对的O(1)。
#include<cstdio>
#include<cstring>
#include<vector>
using namespace std;
struct Man{
int S;
bool like[1005];
Man(const int &S){this->S=S;memset(like,0,sizeof(like));};
Man(){};
};
typedef vector<Man>::iterator ITER;
//5000011
//4000037
vector<Man>v[1005];
int n,m;
int pp,st[2][3200033];
int b[1005];
struct HashTable
{
bool a[5000011],b[4000037];
HashTable(){}
void clear(){
for(int i=1;i<=pp;++i){
a[st[0][i]]=b[st[1][i]]=0;
}
pp=0;
}
void insert(const int &V){
int U1=V%5000011;
a[U1]=1;
int U2=V%4000037;
b[U2]=1;
st[0][++pp]=U1;
st[1][pp]=U2;
}
bool find(const int &V){
return (a[V%5000011] && b[V%4000037]);
}
}T;
char s[105];
int len,S;
void dfs(int cur,int dep,int Snow){
if(dep!=0){
T.insert(Snow);
}
for(int i=cur;i<len;++i){
dfs(i+1,dep+1,Snow|(1<<(s[i]-‘a‘)));
}
}
int main(){
// freopen("h.in","r",stdin);
int x;
scanf("%d",&n);
for(int i=1;i<=n;++i){
scanf("%d",&x);
for(int j=1;j<=x;++j){
scanf("%s",s);
len=strlen(s),S=0;
for(int k=0;k<len;++k){
S|=(1<<(s[k]-‘a‘));
}
v[i].push_back(Man(S));
}
}
scanf("%d",&m);
for(int i=1;i<=m;++i){
scanf("%d",&x);
for(int j=1;j<=x;++j){
scanf("%s",s);
len=strlen(s);
dfs(0,0,0);
}
for(int j=1;j<=n;++j){
for(ITER it=v[j].begin();it!=v[j].end();++it){
if(T.find(it->S)){
it->like[i]=1;
}
}
}
T.clear();
}
for(int i=1;i<=n;++i){
memset(b,0,sizeof(b));
for(ITER it=v[i].begin();it!=v[i].end();++it){
for(int j=1;j<=m;++j){
if(it->like[j]){
++b[j];
}
}
}
int id=1;
for(int j=2;j<=m;++j){
if(b[j]>b[id]){
id=j;
}
}
printf("%d\n",id);
}
return 0;
}
【哈希表】Ural Championship April 30, 2017 Problem H. Hamburgers
标签:str 直接 i+1 pac ++i 存在 highlight char s print
原文地址:http://www.cnblogs.com/autsky-jadek/p/7617749.html