結果
| 問題 |
No.762 PDCAパス
|
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2021-03-23 19:55:17 |
| 言語 | Ruby (3.4.1) |
| 結果 |
AC
|
| 実行時間 | 413 ms / 2,000 ms |
| コード長 | 490 bytes |
| コンパイル時間 | 351 ms |
| コンパイル使用メモリ | 7,296 KB |
| 実行使用メモリ | 22,272 KB |
| 最終ジャッジ日時 | 2024-11-25 21:03:00 |
| 合計ジャッジ時間 | 11,832 ms |
|
ジャッジサーバーID (参考情報) |
judge1 / judge4 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 3 |
| other | AC * 38 |
コンパイルメッセージ
Syntax OK
ソースコード
MOD = 10**9 + 7
N, M = gets.split.map(&:to_i)
S = gets.chomp
graph = Array.new(N) { [] }
PDCA = "PDCA"
M.times do
(s, u), (t, v) = gets.split.map { |s| i = s.to_i - 1; [PDCA.index(S[i]), i] }.minmax
graph[v] << u if s + 1 == t
end
vertices = Array.new(4) { [] }
N.times do |u|
vertices[PDCA.index(S[u])] << u
end
dp = [1] * N
vertices[1, 3].each do |us|
us.each do |u|
dp[u] = graph[u].sum { |v| dp[v] } % MOD
end
end
puts vertices[3].sum { |u| dp[u] } % MOD