东华OJ-基础题-112-密码分析(C++)

  • 问题描述
    密码分析学中常常需要统计字符出现的频度。给定若干行短文,要求按字符出现的频度由高到低输出,当两个字符出现的频度相同时,按字符大小的顺序输出。

注意:只需要统计英文字母的频度,非英文字母一律忽略。

  • 输入说明
    输入由多组数据组成。每组数据由一行长度不超过100的字符串组成,不区分字母大小写,如A与a看作同一个字母。
  • 输出说明
    对每组输入数据都有若干行输出,每行有两个输出数据,第一个数据为某个大写字母,第二个数据为该字母出现的频度,两个数据之间有一个空格。输出顺序按字母出现的频度由高到低输出,当两个字母的频度相同时,按字母大小的顺序输出。两组输出之间有一行空行。
  • 输入范例
cpp 复制代码
Do what you say, say what you do.
This is a test.
Count me 1 2 3 4 5.
  • 输出范例
cpp 复制代码
A 4
O 4
Y 4
D 2
H 2
S 2
T 2
U 2
W 2

S 3
T 3
I 2
A 1
E 1
H 1

C 1
E 1
M 1
N 1
O 1
T 1
U 1

感想:将输入的每一行的字母都转为大写字母,使用辅助数组统计26个字母的各个字母的数量,再将辅助数组里的值赋给使用结构体的数组;按要求排序,输出。
代码如下:

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;

struct Letter {
    char alphar;
    int count;
};

bool compare(const Letter& a,const Letter &b) {
    if(a.count != b.count)
        return a.count > b.count;
    return a.alphar < b.alphar;
}

vector<Letter> toUpperAndCnt(const string & s) {
    vector<int> arr(26,0);
    char ch;
    for(const char& c : s) {
        if(isalpha(c)) {
            ch = toupper(c);
            ++arr[ch-'A'];
        }
    }

    Letter letter;
    vector<Letter> target;
    for(int i = 0; i<26; ++i) {
        if(arr[i]!=0) {
            letter.alphar = 'A' + i;
            letter.count = arr[i];
            target.push_back(letter);
        }
    }

    return target;
}


int main() {
    string input;
    while(getline(cin,input)) {
        vector<Letter> target = toUpperAndCnt(input);
        sort(target.begin(),target.end(),compare);
        for( const auto & ele : target ) {
            cout<<ele.alphar<<" "<<ele.count<<endl;
        }
        cout<<endl;
    }

    return 0;
}
相关推荐
小陈工1 小时前
Python安全编程实践:常见漏洞与防护措施
运维·开发语言·人工智能·python·安全·django·开源
John_ToDebug7 小时前
浏览器扩展延迟加载优化实战:如何让浏览器启动速度提升50%
c++·chrome·windows
是娇娇公主~7 小时前
C++ 中 std::deque 的原理?它内部是如何实现的?
开发语言·c++·stl
SuperEugene7 小时前
Axios 接口请求规范实战:请求参数 / 响应处理 / 异常兜底,避坑中后台 API 调用混乱|API 与异步请求规范篇
开发语言·前端·javascript·vue.js·前端框架·axios
xuxie998 小时前
N11 ARM-irq
java·开发语言
wefly20179 小时前
从使用到原理,深度解析m3u8live.cn—— 基于 HLS.js 的 M3U8 在线播放器实现
java·开发语言·前端·javascript·ecmascript·php·m3u8
luanma1509809 小时前
PHP vs C++:编程语言终极对决
开发语言·c++·php
寂静or沉默9 小时前
2026最新Java岗位从P5-P7的成长面试进阶资源分享!
java·开发语言·面试
csdn_aspnet10 小时前
C/C++ 两个凸多边形之间的切线(Tangents between two Convex Polygons)
c语言·c++·算法
kyriewen1110 小时前
给浏览器画个圈:CSS contain 如何让页面从“卡成PPT”变“丝滑如德芙”
开发语言·前端·javascript·css·chrome·typescript·ecmascript