結果

問題 No.451 575
コンテスト
ユーザー ei1333333
提出日時 2016-12-02 00:44:53
言語 C++11(廃止可能性あり)
(gcc 13.3.0)
結果
WA  
実行時間 -
コード長 798 bytes
コンパイル時間 1,185 ms
コンパイル使用メモリ 158,296 KB
実行使用メモリ 5,248 KB
最終ジャッジ日時 2024-12-16 08:44:24
合計ジャッジ時間 4,708 ms
ジャッジサーバーID
(参考情報)
judge3 / judge5
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 4
other AC * 21 WA * 8
権限があれば一括ダウンロードができます

ソースコード

diff #

#include<bits/stdc++.h>

using namespace std;

typedef long long int64;
int64 RANGE = 1000000000000000000LL;

int main()
{
  int N;
  int64 B[100000];

  cin >> N;

  int64 xs = 1;
  bool f = false;
  for(int i = 0; i < N; i++) {
    cin >> B[i];
    if(i & 1) xs = xs - B[i];
    else xs = B[i] - xs;
    if(xs <= 0 || xs > RANGE) f = true;
  }

  int64 gs = max(1LL, B[0] - 1);
  bool g = false;
  for(int i = 0; i < N; i++) {
    if(i & 1) gs = gs - B[i];
    else gs = B[i] - gs;
    if(gs <= 0 || gs > RANGE) g = true;
  }

  if(f && g) {
    cout << -1 << endl;
    return (0);
  }

  cout << N + 1 << endl;
  int64 rev = 1;
  if(f) rev = B[0] - 1;
  cout << rev << endl;
  for(int i = 0; i < N; i++) {
    if(i & 1) rev = rev - B[i];
    else rev = B[i] - rev;
    cout << rev << endl;
  }
}
0