D. Divide by three, multiply by two

https://codeforces.com/contest/977/problem/D

void solve(){
    int n;
    cin >> n;

    vector<pair<int, long long>> a(n);
    for (auto&[x, y] : a){
        cin >> y;
        x = 0;
        long long temp = y;
        while (temp % 3 == 0){
            x --;
            temp /= 3;
        }
    }

    sort(a.begin(), a.end(), [&](const pair<int, long long>& i, const pair<int ,long long>& j){
            return i.first != j.first ? i.first < j.first : i.second < j.second;
         });

    for (int i = 0; i < n; ++i){
        cout << a[i].second << " \n"[i == n - 1];
    }
}
posted @   _Yxc  阅读(3)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 地球OL攻略 —— 某应届生求职总结
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 提示词工程——AI应用必不可少的技术
· .NET周刊【3月第1期 2025-03-02】
点击右上角即可分享
微信分享提示