結果
| 問題 | 
                            No.126 2基のエレベータ
                             | 
                    
| コンテスト | |
| ユーザー | 
                             | 
                    
| 提出日時 | 2020-08-24 17:58:02 | 
| 言語 | C++17  (gcc 13.3.0 + boost 1.87.0)  | 
                    
| 結果 | 
                             
                                AC
                                 
                             
                            
                         | 
                    
| 実行時間 | 3 ms / 5,000 ms | 
| コード長 | 666 bytes | 
| コンパイル時間 | 2,342 ms | 
| コンパイル使用メモリ | 192,792 KB | 
| 最終ジャッジ日時 | 2025-01-13 13:30:33 | 
| 
                            ジャッジサーバーID (参考情報)  | 
                        judge3 / judge3 | 
(要ログイン)
| ファイルパターン | 結果 | 
|---|---|
| sample | AC * 3 | 
| other | AC * 27 | 
ソースコード
#include <bits/stdc++.h>
using namespace std;
#define REP(i,n) for(int i=0; i<(int)(n); i++)
#define FOR(i,b,e) for (int i=(int)(b); i<(int)(e); i++)
#define ALL(x) (x).begin(), (x).end()
const double PI = acos(-1);
int solve(int a, int b, int s) {
  if (s == 1) return abs(1 - a) + 1;
  if (abs(a-s) <= abs(b-s)) return abs(a-s) + abs(s);
  int r1, r2;
  if (a)
    r1 = abs(s-b) + abs(a-s)+ abs(a);
  else
    r1 = abs(s-b) + abs(1-s) + 2;
  r2 = abs(s-b) + abs(1-s) + abs(1-a) + 1;
  
  return min(r1, r2);
}
int main() {
  ios_base::sync_with_stdio(0);
  cin.tie(0);
  int a, b, s;
  cin >> a >> b >> s;
  cout << solve(a, b, s) << endl;
  
  return 0;
}