結果

問題 No.1251 絶対に間違ってはいけない最小化問題
ユーザー Mister
提出日時 2020-10-09 22:05:09
言語 C++17
(gcc 13.3.0 + boost 1.87.0)
結果
RE  
実行時間 -
コード長 1,036 bytes
コンパイル時間 917 ms
コンパイル使用メモリ 97,496 KB
最終ジャッジ日時 2025-01-15 04:44:49
ジャッジサーバーID
(参考情報)
judge5 / judge4
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3
other AC * 7 RE * 35
権限があれば一括ダウンロードができます

ソースコード

diff #

#include <iostream>
#include <iomanip>
#include <cmath>
#include <vector>
#include <cassert>

using ldouble = long double;
constexpr ldouble INF = 1e6;
constexpr ldouble EPS = 1e-10;

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

    std::vector<ldouble> xs(n), ys(n);
    for (auto& x : xs) std::cin >> x;
    for (auto& y : ys) std::cin >> y;

    auto eval = [&](ldouble x) {
        ldouble ret = 0;
        for (int i = 0; i < n; ++i) {
            ret += std::abs(xs[i] - x) * ys[i];
        }
        return ret;
    };

    ldouble l = -INF, r = INF;
    for (int q = 0; q < 100; ++q) {
        ldouble ll = (l * 2 + r) / 3;
        ldouble rr = (l + r * 2) / 3;

        if (eval(ll) < eval(rr)) {
            r = rr;
        } else {
            l = ll;
        }
    }

    int ans = std::round(l);
    assert(std::abs(eval(ans) - eval(l)) < EPS);

    std::cout << ans << " " << std::llround(eval(ans)) << "\n";
}

int main() {
    std::cin.tie(nullptr);
    std::ios::sync_with_stdio(false);

    solve();

    return 0;
}
0