题解 | #字符统计#

字符统计

http://www.nowcoder.com/practice/c1f9561de1e240099bdb904765da9ad0

map也可以传比较函数进去,不过注意map比较的是key,不是比较的pair.还有ASII码要升序排但次数要降序排

#include <algorithm>
#include <map>
#include <vector>


using namespace std;

bool compare( const char&lhs, const char&rhs){
    return lhs<rhs;
    
}

int main() {
    string str;
    map<char,int,decltype(compare)*> m(compare);
    while(cin>>str){
        for(int i = 0;i<str.size();i++){
           m[str[i]]++;
            
        }
        vector<char> v;
        for(auto it = m.begin();it!=m.end();it++){
            v.push_back((*it).first);
            
        }
        int n =v.size();
        char temp;
        for(int i=0;i<n;i++){
            
            for(int j = 0;j<n-i-1;j++){
                if(m[v[j]]<m[v[j+1]]){
                    swap(v[j],v[j+1]);
                }
            }
        }
        for(auto it:v){
            cout<<it;
        }
    }
}
全部评论

相关推荐

大野鸡:其实就是量,但是时间有限,1000题只要不是全中等简单,简单中等困难1-2-1,大概能打打比赛了(前20%),10000题就是下一个灵神
点赞 评论 收藏
分享
10-19 14:15
兰州大学 Java
_Philia093:蓝桥杯省三删掉
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务