华为机考:HJ102 字符统计

华为机考:HJ102 字符统计

描述

在这里插入图片描述

方法1

先将所有字符计算数量,在对比其中字符的assic码

#include<iostream>
#include<vector>
#include<algorithm>
#include<string>
using namespace std;
bool cmp(pair<char, int> a, pair<char, int> b) {
    if (a.second > b.second) {
        return true;
    } else if (a.second == b.second) {
        return a.first < b.first;
    } else {
        return false;
    }
}

int main() {
    string s;
    while (cin >> s) {
        vector<pair<char, int>> vec;
        for (int i = 0; i < s.length(); ++i) {
            vector<pair<char, int>>::iterator it;
            for (it = vec.begin(); it != vec.end(); ++it) {
                if (it->first == s[i]) {
                    it->second++;
                    break;
                }
            }
            if (it == vec.end()) {
                vec.push_back(make_pair(s[i], 1));
            }
        }
        sort(vec.begin(), vec.end(), cmp);
        for (int i = 0; i < vec.size(); ++i) {
            cout << vec[i].first;
        }
        cout << endl;
    }
    return 0;
}

方法2

与方法一一样,不过使用stl比较

#include<iostream>
#include<map>
#include<string>
#include<vector>
#include<iterator>
#include<algorithm>
using namespace std;
int main()
{
	string s;
	map<char, int> mp;
	while (cin >> s) {
		mp.clear();
		for (char c : s) {
			++mp[c];
		}
		vector<pair<char, int>> vec(mp.begin(),mp.end());
		stable_sort(vec.begin(), vec.end(), [](const pair<char, int>& a, const
			 pair<char, int>& b) {
				return a.second > b.second;
			});
		for (auto iter = vec.begin();iter != vec.end();++iter) {
			cout << iter->first;
		}
		cout << endl;
	}
	return 0;
}

相关推荐

  1. 华为试打卡 HJ102 字符统计

    2024-03-13 06:32:01       15 阅读
  2. 华为HJ2 计算某字符出现次数

    2024-03-13 06:32:01       23 阅读
  3. HJ10 字符个数统计【C语言】

    2024-03-13 06:32:01       34 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-03-13 06:32:01       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-03-13 06:32:01       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-03-13 06:32:01       19 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-03-13 06:32:01       20 阅读

热门阅读

  1. 1792. 最大平均通过率

    2024-03-13 06:32:01       19 阅读
  2. Linux 安装使用 Docker

    2024-03-13 06:32:01       22 阅读
  3. 环境部署(jar、nginx、redis、mysql57)

    2024-03-13 06:32:01       18 阅读
  4. Flink SQL CDC 配置文档

    2024-03-13 06:32:01       24 阅读
  5. Django中的ajax细节

    2024-03-13 06:32:01       18 阅读
  6. 【Vue】首屏加载优化

    2024-03-13 06:32:01       23 阅读
  7. webpack一些常用的Loader和Plugin

    2024-03-13 06:32:01       23 阅读
  8. Anaconda3安装pandas失败,处理办法

    2024-03-13 06:32:01       22 阅读