結果

問題 No.451 575
ユーザー mai
提出日時 2016-12-02 01:16:04
言語 Ruby
(3.4.1)
結果
WA  
実行時間 -
コード長 732 bytes
コンパイル時間 273 ms
コンパイル使用メモリ 7,552 KB
実行使用メモリ 14,080 KB
最終ジャッジ日時 2024-12-16 09:18:23
合計ジャッジ時間 7,193 ms
ジャッジサーバーID
(参考情報)
judge3 / judge1
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 4
other AC * 21 WA * 8
権限があれば一括ダウンロードができます
コンパイルメッセージ
Syntax OK

ソースコード

diff #

@n = gets.to_i

@data = Array.new(@n)
@result = Array.new(@n+1)

@n.times{|i| @data[i] = gets.to_i}

1.upto(20){|k|
    def calc(k)
        b = k
        return false if b<=0 
        @result[0] = k
        @n.times{|i|
            b = @result[i+1] = (@data[i]-b) if i%2==0
            b = @result[i+1] = (b-@data[i]) if i%2==1
            if (b<=0 || 10**18<b)
                return false
            end
        }
        return true
    end
    if !calc(k)
        @result[0]=nil
        next
    else
        break
    end
}
if !@result[0]
    puts "-1";exit
end

puts @n+1
@result.each{|e| puts e}

#0.upto(@n-1){|i|
#    p @result[i]+@result[i+1] == @data[i] if i%2==0
#    p @result[i]-@result[i+1] == @data[i] if i%2==1
#}
0