結果

問題 No.126 2基のエレベータ
ユーザー Tatsu_mr
提出日時 2024-11-04 22:29:57
言語 C++23
(gcc 13.3.0 + boost 1.87.0)
結果
WA  
実行時間 -
コード長 916 bytes
コンパイル時間 2,904 ms
コンパイル使用メモリ 244,072 KB
実行使用メモリ 6,824 KB
最終ジャッジ日時 2024-11-04 22:30:02
合計ジャッジ時間 4,254 ms
ジャッジサーバーID
(参考情報)
judge4 / judge1
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3
other AC * 25 WA * 2
権限があれば一括ダウンロードができます

ソースコード

diff #

#include <bits/stdc++.h>
#define For(i, a, b) for(int i = a; i < b; i++)
#define rep(i, n) For(i, 0, n)
#define rFor(i, a, b) for(int i = a; i >= b; i--)
#define ALL(v) (v).begin(), (v).end()
#define rALL(v) (v).rbegin(), (v).rend()
using namespace std;

using lint = long long;
using ld = long double;

int INF = 2000000000;
lint LINF = 1000000000000000000;

int main() {
    int a, b, s;
    cin >> a >> b >> s;
    if (s == 1) {
        cout << abs(a - 1) + 1 << endl;
        return 0;
    }
    if (abs(s - a) <= abs(s - b)) {
        cout << abs(a - s) + s << endl;
        return 0;
    }
    if (s <= b && b <= a) {
        cout << min(b - 1 + a, b - s + a - s + a) << endl;
    } else if (a <= s && s <= b) {
        cout << b << endl;
    } else if (b <= s && s <= a) {
        cout << min(a - b + a, s - b + s - 1 + a) << endl;
    } else if (a <= b && b <= s) {
        cout << s - b + s << endl;
    }
}
0