結果
| 問題 | 
                            No.282 おもりと天秤(2)
                             | 
                    
| コンテスト | |
| ユーザー | 
                             | 
                    
| 提出日時 | 2015-09-28 15:25:29 | 
| 言語 | Crystal  (1.14.0)  | 
                    
| 結果 | 
                             
                                CE
                                 
                             
                            
                            (最新)
                                AC
                                 
                             
                            (最初)
                            
                            
                         | 
                    
| 実行時間 | - | 
| コード長 | 604 bytes | 
| コンパイル時間 | 3,678 ms | 
| コンパイル使用メモリ | 217,260 KB | 
| 最終ジャッジ日時 | 2024-11-14 19:17:03 | 
| 合計ジャッジ時間 | 5,158 ms | 
| 
                            ジャッジサーバーID (参考情報)  | 
                        judge4 / judge1 | 
(要ログイン)
コンパイルエラー時のメッセージ・ソースコードは、提出者また管理者しか表示できないようにしております。(リジャッジ後のコンパイルエラーは公開されます)
ただし、clay言語の場合は開発者のデバッグのため、公開されます。
            
            
            
            
            ただし、clay言語の場合は開発者のデバッグのため、公開されます。
コンパイルメッセージ
[2mShowing last frame. Use --error-trace for full trace.[0m
In [4mMain.cr:19:50[0m
[2m 19 | [0m[1mq=N%2==0 ? A[0...N].each_slice(2).flat_map{|e|e}+[0]*N : A[0...N-1].each_slice(2).flat_map{|e|e}+[0]*(N+1)[0m
                                                      [32;1m^[0m
[33;1mError: undefined method '+' for Iterator::FlatMapIterator(Iterator::SliceIterator(Indexable::ItemIterator(Array(Int32), Int32), Int32, Int32), Int32, Indexable::ItemIterator(Array(Int32), Int32), Proc(Array(Int32), Array(Int32)))[0m
            
            ソースコード
#!/usr/bin/env crystal
def perform(q,start)
	puts "? "+q.join(" ")
	STDOUT.flush
	f=true
	gets.not_nil!.split.each_with_index(0){|e,i|
		if e==">"
			f=false
			A[i*2+0+start],A[i*2+1+start]=A[i*2+1+start],A[i*2+0+start]
		end
	}
	STDERR.puts A.join(" ")
	f	
end
N=gets.not_nil!.to_i
A=(1..N).to_a
f=true
while f
	q=N%2==0 ? A[0...N].each_slice(2).flat_map{|e|e}+[0]*N : A[0...N-1].each_slice(2).flat_map{|e|e}+[0]*(N+1)
	break if perform(q,0)
	q=N%2==0 ? A[1...N-1].each_slice(2).flat_map{|e|e}+[0]*(N+2) : A[1...N].each_slice(2).flat_map{|e|e}+[0]*(N+1)
	break if perform(q,1)
end
puts "! "+A.join(" ")