Java教程

统计字母

本文主要是介绍统计字母,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

方块游戏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;
}
这篇关于统计字母的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!