题解 CF43B 【Letter】

本文介绍了一种使用C++实现的字符串匹配算法,通过统计字符串中各字母出现次数来判断是否能从一个字符串中组合出另一个字符串。文章提供了一个具体的代码示例,展示了如何使用数组来记录每个字母的出现频率。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

这道题目,对于 C ++的选手,考察的是字符串 。字符串的类型定义是 string 字符串是 C 语言里没有的。对于这道题,用字符串要比用字符数组要方便。

这一题,由于串里不是字母就是空格,所以我们可以采用统计的方式,开两个数组,用于存储字母 A ~ z 。我们又知道字符 A 的 ASCII 码是 64,字符 z 的 ASCII 码是 123 ,所以我们只要开 70 的数组就可以了。

下面就可以进行代码的实现了:

#include<bits/stdc++.h>
#define maxn 70//此处为定义maxn为70
using namespace std;
string s,t;
int a[maxn],b[maxn],i;
int main(){
    getline(cin,s);//string的输入方式之一
    getline(cin,t);
    for(i=0;i<s.size();i++)//s.size()是在测s的串长
        if(s[i]!=' ')
            a[s[i]-'A'+1]++;//A是第一个,B是第二个,以此类推
    for(i=0;i<t.size();i++)
        if(t[i]!=' ')
            b[t[i]-'A'+1]++;
    for(i=1;i<='z'-'A'+1;i++)
        if(a[i]<b[i]){
            printf("NO");//如果报纸上的字母个数比匿名信的还少,就说明不能写信,所以直接输出NO,return 0
            return 0;
        }
    printf("YES");//如果没有return 0就说明可以写匿名信
    return 0;
}

转载于:https://www.cnblogs.com/SeashellBaylor/p/11193947.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值