結果

問題 No.154 市バス
ユーザー tshigtshig
提出日時 2016-08-05 15:17:38
言語 Ruby
(3.3.0)
結果
AC  
実行時間 533 ms / 2,000 ms
コード長 748 bytes
コンパイル時間 196 ms
コンパイル使用メモリ 7,296 KB
実行使用メモリ 14,464 KB
最終ジャッジ日時 2024-10-13 08:41:56
合計ジャッジ時間 4,304 ms
ジャッジサーバーID
(参考情報)
judge5 / judge4
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 521 ms
14,080 KB
testcase_01 AC 524 ms
14,336 KB
testcase_02 AC 520 ms
14,464 KB
testcase_03 AC 203 ms
14,464 KB
testcase_04 AC 517 ms
14,336 KB
testcase_05 AC 84 ms
12,032 KB
testcase_06 AC 86 ms
12,160 KB
testcase_07 AC 533 ms
14,336 KB
testcase_08 AC 82 ms
12,288 KB
権限があれば一括ダウンロードができます
コンパイルメッセージ
Syntax OK

ソースコード

diff #

class Calc0154
  def initialize(args)
    args = args.map { |l| l.chomp.split(/\s+/) }
    @n = args.shift.first.to_i
    @ss = args.map(&:first)
  end

  def calc(s)
    ws = s.count('W')
    gs = s.count('G')
    rs = s.count('R')
    !s.end_with?('W') &&
      ws >= 1 && gs >= 1 && rs >= 1 &&
      s.rindex('W') < s.rindex('G') &&
      gs == rs && check_times(s)
  end

  def check_times(s)
    ws = gs = rs = 0
    s.split(//).each do |c|
      ws += 1 if c == 'W'
      gs += 1 if c == 'G'
      rs += 1 if c == 'R'
      return false if gs > ws || rs > gs
    end
    true
  end

  def run
    @ss.map { |s| calc(s) }.map { |r| r ? 'possible' : 'impossible' }.join("\n")
  end
end

puts Calc0154.new(STDIN.readlines).run if __FILE__ == $0
0