結果

問題 No.190 Dry Wet Moist
ユーザー maine_honzuki
提出日時 2020-11-23 01:43:35
言語 C++17
(gcc 13.3.0 + boost 1.87.0)
結果
AC  
実行時間 102 ms / 2,000 ms
コード長 877 bytes
コンパイル時間 2,876 ms
コンパイル使用メモリ 197,960 KB
最終ジャッジ日時 2025-01-16 04:49:57
ジャッジサーバーID
(参考情報)
judge4 / judge1
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 2
other AC * 28
権限があれば一括ダウンロードができます

ソースコード

diff #

#include <bits/stdc++.h>
using namespace std;

int maine(vector<int>& A) {
    int book = 0;
    int l = 0, r = A.size() - 1;
    while (l < r) {
        if (A[l] + A[r] < 0) {
            book++;
            l++;
            r--;
        } else
            r--;
    }
    return book;
}

int main() {
    int N;
    cin >> N;
    vector<int> A(N * 2);
    for (int i = 0; i < N * 2; i++) {
        cin >> A[i];
    }

    int dry, wet, moist;
    sort(A.begin(), A.end());
    dry = maine(A);
    reverse(A.begin(), A.end());
    for (auto& x : A)
        x *= -1;
    wet = maine(A);

    int cnt[1000010] = {};
    for (auto& x : A) {
        cnt[x + 100000]++;
    }

    moist = 0;
    for (int i = 1; i <= 100000; i++) {
        moist += min(cnt[100000 + i], cnt[100000 - i]);
    }
    moist += cnt[100000] / 2;

    cout << dry << " " << wet << " " << moist << endl;
}
0