统计字母

方块游戏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;
}
上一篇:Python|利用BFS求表格中的最短路径


下一篇:xjoi9222