方块游戏https://www.acwing.com/problem/content/1815/
例如,如果 N=3 且单词 box,cat,car 朝上显示,则奶牛至少需要一个 b 块,一个 o 块,一个 x 块,两个 c 块,两个 a 块,一个 t 块和一个 r 块。
请帮助约翰确定,印有每种字母的木块至少需要提供多少块,才能使得不管每个板子的哪一侧朝上显示,奶牛都可以拼出所有 N 个可见的单词。
#include <bits/stdc++.h>
using namespace std;
const int N=110;
string a[N],b[N];
int main()
{
int n;cin>>n;
for (int i = 0; i < n; i ++ ){
cin>>a[i]>>b[i];
}
int res[26]={0};
for(int i=0;i<n;i++){
int x[26]={0},y[26]={0};
for(auto c:a[i]) x[c-'a']++; //正面的字母出现次数
for(auto c:b[i]) y[c-'a']++; //反面
for (int j = 0; j < 26; j ++ )
res[j]+=max(x[j],y[j]);//结果更新 到了i这快板后 正面或反面的某个字母最大的次数
}
for (int i = 0; i < 26; i ++ )
cout<<res[i]<<endl;
return 0;
}