QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#256230#7750. Revenge on My Bossucup-team1055WA 0ms3600kbC++203.9kb2023-11-18 18:07:312023-11-18 18:07:31

Judging History

你现在查看的是最新测评结果

  • [2023-11-18 18:07:31]
  • 评测
  • 测评结果:WA
  • 用时:0ms
  • 内存:3600kb
  • [2023-11-18 18:07:31]
  • 提交

answer

#include <bits/stdc++.h>

#define rep(i, s, n) for (int i = int(s); i < int(n); i++)
#define rrep(i, s, n) for (int i = int(n) - 1; i >= int(s); i--)
#define all(v) (v).begin(), (v).end()

using ll = long long;
using ull = unsigned long long;
using ld = long double;
using i128 = __int128_t;

template <class T> bool chmin(T &a, T b) {
    if (a <= b) return false;
    a = b;
    return true;
}

template <class T> bool chmax(T &a, T b) {
    if (a >= b) return false;
    a = b;
    return true;
}

void solve() {
    int n;
    std::cin >> n;
    std::vector<ll> a(n), b(n), c(n);
    ll sum_a = 0;
    std::vector<int> neg, pos, zero;
    rep(i, 0, n) {
        std::cin >> a[i] >> b[i] >> c[i];
        sum_a += a[i];
        if (b[i] - a[i] < 0) {
            neg.emplace_back(i);
        } else if (b[i] - a[i] == 0) {
            zero.emplace_back(i);
        } else {
            pos.emplace_back(i);
        }
    }
    auto check = [&](ll x) -> std::vector<int> {
        std::vector<int> p;
        ll sum = 0;
        std::sort(all(neg), [&](int i, int j) -> bool {
            ll lhs = x - (sum_a * c[i] + b[i] * c[i]);
            ll rhs = x - (sum_a * c[j] + b[j] * c[j]);
            return i128(lhs) * c[j] > i128(rhs) * c[i];
        });
        for (auto i : neg) {
            if (sum * c[i] + sum_a * c[i] + b[i] * c[i] > x) {
                return {};
            }
            sum += b[i] - a[i];
            p.emplace_back(i);
        }
        for (auto i : zero) {
            if (sum * c[i] + sum_a * c[i] + b[i] * c[i] > x) {
                return {};
            }
            sum += b[i] - a[i];
            p.emplace_back(i);
        }
        using P = std::pair<ll, int>;
        std::priority_queue<P> pq;
        std::queue<int> que;
        /*
        std::sort(all(pos), [&](int i, int j) -> bool {
            ll lhs = x - (sum_a * c[i] + b[i] * c[i]);
            ll rhs = x - (sum_a * c[j] + b[j] * c[j]);
            return i128(lhs) * c[j] > i128(rhs) * c[i];
        });
        */
        for (auto i : pos) {
            sum += b[i] - a[i];
        }
        for (auto i : pos) {
            ll ret = x - (sum_a * c[i] + b[i] * c[i]);
            if (ret < 0) {
                if (ret % c[i] == 0)
                    ret /= c[i];
                else {
                    ret /= c[i];
                    ret--;
                }
            } else
                ret /= c[i];
            pq.push({ret + (b[i] - a[i]), i});
        }
        while (!pq.empty()) {
            auto [ret, i] = pq.top();
            if (sum <= ret) {
                que.push(i);
                pq.pop();
            } else {
                break;
            }
        }
        while (!que.empty()) {
            int i = que.front();
            que.pop();
            sum -= b[i] - a[i];
            if (sum * c[i] + sum_a * c[i] + b[i] * c[i] > x) {
                return {};
            }
            while (!pq.empty()) {
                auto [ret, j] = pq.top();
                if (sum <= ret) {
                    que.push(j);
                    pq.pop();
                } else {
                    break;
                }
            }
        }
        if(!pq.empty()) {
            return {};
        }
        std::reverse(all(p));
        auto ans = pos;
        ans.insert(ans.end(), all(p));
        return ans;
    };
    ll ok = 2'000'000'000'000'000'000;
    ll ng = 0;
    while ((ok - ng) > 1) {
        ll mid = (ok + ng) >> 1;
        auto ret = check(mid);
        if (ret.empty()) {
            ng = mid;
        } else {
            ok = mid;
        }
    }
    auto ans = check(ok);
    rep(i, 0, n) {
        std::cout << ans[i] + 1 << " \n"[i == n - 1];
    }
}

int main() {
    std::cin.tie(nullptr);
    std::ios::sync_with_stdio(false);
    int t;
    std::cin >> t;
    while (t--) {
        solve();
    }
}

详细

Test #1:

score: 0
Wrong Answer
time: 0ms
memory: 3600kb

input:

2
4
1 1 4
5 1 5
1 9 1
9 8 1
9
3 1 4
1 5 9
2 6 5
3 5 8
9 7 9
3 2 3
8 4 6
2 6 8
3 2 7

output:

3 1 2 4
2 3 4 8 5 9 7 1 6

result:

wrong answer Wrong Answer on Case#2