結果

問題 No.305 鍵(2)
ユーザー maimai
提出日時 2016-06-01 13:15:59
言語 Ruby
(3.3.0)
結果
AC  
実行時間 112 ms / 2,000 ms
コード長 602 bytes
コンパイル時間 204 ms
コンパイル使用メモリ 7,424 KB
実行使用メモリ 29,024 KB
平均クエリ数 44.08
最終ジャッジ日時 2024-07-16 23:53:33
合計ジャッジ時間 2,933 ms
ジャッジサーバーID
(参考情報)
judge3 / judge2
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 112 ms
28,896 KB
testcase_01 AC 105 ms
28,768 KB
testcase_02 AC 101 ms
29,024 KB
testcase_03 AC 103 ms
28,256 KB
testcase_04 AC 104 ms
28,640 KB
testcase_05 AC 106 ms
28,552 KB
testcase_06 AC 98 ms
28,768 KB
testcase_07 AC 102 ms
28,896 KB
testcase_08 AC 105 ms
29,024 KB
testcase_09 AC 99 ms
28,512 KB
testcase_10 AC 103 ms
28,512 KB
testcase_11 AC 102 ms
28,664 KB
testcase_12 AC 106 ms
28,768 KB
権限があれば一括ダウンロードができます
コンパイルメッセージ
Syntax OK

ソースコード

diff #

key=[0]*10
lock=[false]*10

keyprev=nil
changedidx=nil
jprev=nil
loop{
    puts key*"";STDOUT.flush
    j=gets.split(" ")[0].to_i
    exit if j==10
    
    if jprev==nil
        changedidx=0
        jprev=j
    else
        if jprev < j # 正解増えた
            lock[changedidx]=true
            jprev=j
        elsif jprev > j # 減った
            lock[changedidx]=true
            key = keyprev.clone
        end
    end
    
    changedidx.upto(9){|i|
        next if lock[i]
        
        keyprev = key.clone
        changedidx=i
        key[i]=(key[i]+1)%10
        break
    }
    
}
0