문제만 읽어보면 간단히 위상 정렬로 해결할 수 있을 것 같은데, 예시 입출력을 확인하면 그렇지 않다.
위상 정렬은 DAG, 사이클이 없는 방향그래프에만 적용할 수 있는데 이 문제는 각 물약(정점)들이 서로를 선행 노드로 가리키는 경우가 발생한다.
이는 정점 단위로 그래프를 구성해야 한다는 생각을 가지기 때문인데, 문제에서는 물약을 만들 수 있는 레시피 가 주어지므로 임의의 정점의 선행 정점들은 다른 정점이 아닌 레시피이다.
또, 정점을 탐색하며 갱신해 나가는 방식에서, 만들어지지 않은 물약들을 기준으로 탐색하게 되면 결국 다시 재귀적으로 시작 지점으로 돌아와 가면서 탐색해야 한다는 단점이 있으므로 만들어진 물약들을 기준으로 탐색해야 하는데 이 경우 만들어진 물약을 가지고 만들 수 있는 물약의 정보도 각 정점이 포함해야 한다.
따라서 각 정점은 다음과 같은 정보를 포함해야 한다.
물약 번호(이 정보는 배열의 인덱스로 대체 가능)
물약의 레시피(들. 임의의 물약 $r$을 만드는 레시피가 반드시 1개인 것은 아니다.)
해당 물약이 재료가 되는 물약들
해당 물약을 가지고 있는지 여부
따라서 문제의 예시 입출력에 주어진 조건 일부를 각각 도식화하면 다음과 같다.
…
3 1 5 7 2
…
2 3 4 5
2 4 5 3
2 5 6 4
결국, 각 물약들의 레시피와 가지고 있는 물약이 주어지면, 가지고 있는 물약들을 기준으로 만들 수 있는 물약들(next)을 탐색하며 각 물약들이 가진 레시피들(recipes) 중 하나라도 모든 구성 물약을 가지고 있는 레시피가 있다면 belong을 true로 변경하고 가지고 있는 물약 리스트에 해당 물약을 추가한다.