結果
| 問題 | 
                            No.532 Possible or Impossible
                             | 
                    
| コンテスト | |
| ユーザー | 
                             | 
                    
| 提出日時 | 2017-06-30 17:22:26 | 
| 言語 | Ruby  (3.4.1)  | 
                    
| 結果 | 
                             
                                WA
                                 
                             
                            
                         | 
                    
| 実行時間 | - | 
| コード長 | 445 bytes | 
| コンパイル時間 | 219 ms | 
| コンパイル使用メモリ | 7,808 KB | 
| 実行使用メモリ | 12,288 KB | 
| 最終ジャッジ日時 | 2024-10-04 18:36:30 | 
| 合計ジャッジ時間 | 2,712 ms | 
| 
                            ジャッジサーバーID (参考情報)  | 
                        judge5 / judge2 | 
(要ログイン)
| ファイルパターン | 結果 | 
|---|---|
| other | AC * 22 WA * 1 | 
コンパイルメッセージ
Syntax OK
ソースコード
def dfs(xs, goal)
  if xs.size == 1
    x = xs[0]
    return (goal == x)
  end
  x = xs.shift
  y = xs.shift
  can = []
  can << x + y
  can << x - y
  can << y - x
  can << x * y
  can << y / x if x != 0
  can << x / y if y != 0
  can.each do |z|
    return true if dfs([z] + xs, goal)
  end
  false
end
def solve(n, goal)
  a = (1..n).to_a
  dfs a, goal
end
m, n = gets.chomp.split.map(&:to_i)
puts solve(m, n) ? :Possible : :Impossible