例如,如果 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; }