結果
| 問題 | 
                            No.1389 Clumsy Calculation
                             | 
                    
| コンテスト | |
| ユーザー | 
                             | 
                    
| 提出日時 | 2023-06-14 15:40:24 | 
| 言語 | C++14  (gcc 13.3.0 + boost 1.87.0)  | 
                    
| 結果 | 
                             
                                AC
                                 
                             
                            
                         | 
                    
| 実行時間 | 81 ms / 2,000 ms | 
| コード長 | 808 bytes | 
| コンパイル時間 | 1,708 ms | 
| コンパイル使用メモリ | 170,032 KB | 
| 実行使用メモリ | 7,296 KB | 
| 最終ジャッジ日時 | 2024-06-23 00:29:07 | 
| 合計ジャッジ時間 | 4,567 ms | 
| 
                            ジャッジサーバーID (参考情報)  | 
                        judge2 / judge4 | 
(要ログイン)
| ファイルパターン | 結果 | 
|---|---|
| sample | AC * 3 | 
| other | AC * 26 | 
ソースコード
#include <bits/stdc++.h>
using namespace std;
using ll = long long;
using Graph = vector<vector<int>>;
int main() {
  long long N,X; cin >> N >> X;
  vector<int> A(N);
  long long Z = (N - 1) * X;
  for(int i = 0; i < N; i++) cin >> A[i];
  long long sum = 0;
  for(int i = 0; i < N; i++) {
    sum += A[i];
  }
  long long a = Z - sum;
  vector<long long> W(N);
  vector<long long> E(N);
  sum = 0;
  long long t = 0;
  for(int i = N - 1; i >= 0; i--) {
    sum += A[i];
    t += (X - A[i]);
    E[i] = t;
    W[i] = sum;
  }
  sum = 0;
  t = 0;
  for(int i = 0; i < N; i++) {
    long long Y = sum + W[i];
    long long y = Y + a;
    long long S = t + E[i];
    if(A[i]% 2 == 0 && y == Z && S + A[i]/2 == X) {
      cout << A[i]/2ll << endl;
      break;
    }
    sum += A[i];
    t += (X - A[i]);
  }
}