有向グラフのループ パスを見つけて返す関数を Scala で作成しました。プログラムは次のとおりで、引数の 1 つは隣接するリストに表示されるグラフであり、もう 1 つは開始ノードです。ノードのリストでループパスを含むペアを返します。
もっとエレガントな方法があるのだろうか。もしよろしければ、あなたの考えを共有してください。ありがとう。
def GetACycle(start: String, maps: Map[String, List[String]]): (Boolean, List[String]) = {
def explore(node: String, visits: List[String]): (Boolean, List[String]) = {
if (visits.contains(node)) (true, (visits.+:(node)).reverse)
else {
if (maps(node).isEmpty) (false, List())
else {
val id = maps(node).indexWhere(x => explore(x, visits.+:(node))._1)
if (id.!=(-1))
explore(maps(node)(id), visits.+:(node))
else
(false, List())
}
}
}
explore(start, List())
}
この状況では indexWhere を使用する必要があると感じましたが、それを行うには他の方法があると思います。