zoukankan      html  css  js  c++  java
  • ACM 字母统计

    字母统计

    时间限制:3000 ms  |  内存限制:65535 KB
    难度:1
     
    描述
    现在给你一个由小写字母组成字符串,要你找出字符串中出现次数最多的字母,如果出现次数最多字母有多个那么输出最小的那个。
     
    输入
    第一行输入一个正整数T(0<T<25)
    随后T行输入一个字符串s,s长度小于1010。
    输出
    每组数据输出占一行,输出出现次数最多的字符;
    样例输入
    3
    abcd
    bbaa
    jsdhfjkshdfjksahdfjkhsajkf
    样例输出
    a
    a
    j
    时间限制:3000 ms  |  内存限制:65535 KB
    难度:1
     
    描述
    现在给你一个由小写字母组成字符串,要你找出字符串中出现次数最多的字母,如果出现次数最多字母有多个那么输出最小的那个。
     
    输入
    第一行输入一个正整数T(0<T<25)
    随后T行输入一个字符串s,s长度小于1010。
    输出
    每组数据输出占一行,输出出现次数最多的字符;
    样例输入
    3
    abcd
    bbaa
    jsdhfjkshdfjksahdfjkhsajkf
    样例输出
    a
    a
    j
    #include <iostream>
    #include <algorithm>
    #include <vector>
    #include <string>
    using namespace std;
    
    struct WordCnt{
        char ch;
        int cnt;
        WordCnt(int aCh, int aCnt):ch(aCh),cnt(aCnt){}
        bool operator <(const WordCnt &a) const{
            if(cnt!=a.cnt) return cnt > a.cnt;
            else return ch < a.ch;
        }
    };
    
    int main(){
        int T;
        cin >> T;
        for (int icase =  0; icase < T; ++icase) {
            string str;
            cin >>str;
            vector<WordCnt> word;
            for (int i = 0;  i < str.length(); ++ i) {
                int  j = 0;
                for (j = 0; j < word.size(); ++ j) {
                    if(word[j].ch == str[i]) word[j].cnt++;
                }
                if(j == word.size()) word.push_back(WordCnt(str[i],1));
            }
            sort(word.begin(),word.end());
            cout<<word[0].ch<<endl;
            
        }
    }
  • 相关阅读:
    javascritp对fckeditor编辑器赋值取值
    [.net]发布基于C#与Flash通信的游戏设计器完整项目及源代码下载
    Sun VirtualBox更新到3.0.8.53138
    JavaScript强弹代码
    给Repeater、Datalist和Datagrid增加自动编号列
    Adobe发布新版Photoshop.com 支持iPhone
    网站免费提交搜索引擎入口地址?
    利用FMS做在线视频录制
    Apache Lucene 2.9的改进
    KDE 4.3.2 发布
  • 原文地址:https://www.cnblogs.com/xiongqiangcs/p/3642783.html
Copyright © 2011-2022 走看看