문제
링크
풀이
#include <algorithm>
#include <iostream>
#include <map>
#include <utility>
#include <vector>
using namespace std;
struct Number {
int value, count, index;
};
inline bool cmp(const Number &a, const Number &b) {
if (a.count != b.count) return a.count > b.count;
return a.index < b.index;
}
void solve(void) {
int n, c; cin >> n >> c;
vector<int> v(n);
for (int i=0; i<n; i++) cin >> v[i];
map<int, pair<int, int>> mp;
for (int i=0; i<n; i++) {
if (mp.find(v[i]) == mp.end()) mp[v[i]] = {1, i};
else mp[v[i]].first++;
}
vector<Number> numbers;
for (auto [p, q] : mp) {
numbers.push_back({p, q.first, q.second});
}
sort(numbers.begin(), numbers.end(), cmp);
for (int i=0; i<numbers.size(); i++) {
for (int j=0; j<numbers[i].count; j++) {
cout << numbers[i].value << " ";
}
}
}
int main(void) {
ios::sync_with_stdio(false);
cin.tie(nullptr);
solve();
return 0;
}