题解 | #字符统计#
字符统计
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;
        }
    }
}
 查看12道真题和解析
查看12道真题和解析


 投递字节跳动等公司10个岗位
投递字节跳动等公司10个岗位