結果
問題 | No.2247 01 ZigZag |
ユーザー |
![]() |
提出日時 | 2023-03-18 16:20:42 |
言語 | Ruby (3.4.1) |
結果 |
WA
(最新)
AC
(最初)
|
実行時間 | - |
コード長 | 1,331 bytes |
コンパイル時間 | 211 ms |
コンパイル使用メモリ | 7,296 KB |
実行使用メモリ | 14,720 KB |
最終ジャッジ日時 | 2024-09-18 16:15:30 |
合計ジャッジ時間 | 7,516 ms |
ジャッジサーバーID (参考情報) |
judge2 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 2 |
other | AC * 49 WA * 1 |
コンパイルメッセージ
Main.rb:87: warning: ambiguous first argument; put parentheses or a space even after `-' operator Syntax OK
ソースコード
N, M, K = gets.split.map(&:to_i)def f(n, m, k)zero_stack = []one_stack = [](k + 1).times do |i|if i.even?zero_stack << 1elseone_stack << 1endendif zero_stack.size > nreturn falseendif one_stack.size > mreturn falseendzero_stack[0] += n - zero_stack.size if zero_stack.size > 0one_stack[-1] += m - one_stack.size if one_stack.size > 0res = ''i = 0while zero_stack.size > 0 || one_stack.size > 0if i.even?res << '0' * zero_stack.shiftelseres << '1' * one_stack.shiftendi += 1endresenddef g(n, m, k)zero_stack = []one_stack = [](k + 1).times do |i|if i.even?one_stack << 1elsezero_stack << 1endendif zero_stack.size > nreturn falseendif one_stack.size > mreturn falseendzero_stack[0] += n - zero_stack.size if zero_stack.size > 0one_stack[-1] += m - one_stack.size if one_stack.size > 0res = ''i = 0while zero_stack.size > 0 || one_stack.size > 0if i.even?res << '1' * one_stack.shiftelseres << '0' * zero_stack.shiftendi += 1 endresendres1 = f(N, M, K)res2 = g(N, M, K)ans = []ans << res1 if res1ans << res2 if res2if ans.empty?puts -1elseputs ans.sort.firstend