문제 링크입니다: https://www.acmicpc.net/problem/2823 처음에는 BFS 알고리즘으로 접근했다가 틀렸던 문제였습니다. 알고리즘은 아래와 같습니다.1. 마을을 전부 탐색하는데 빌딩이면 지나가고, 길일 경우에만 상하좌우로 탐색합니다.2. 길을 기준으로 상하좌우에 길이 없거나 길이 한군데에만 뚫려있을 경우 반드시 유턴을 해야합니다.-> 따라서, 이런 케이스가 발생하면 사이클이 있다고 표시하고 반복문을 탈출합니다.3. 사이클이 있을 경우 0, 없는 경우 1을 출력해줍니다. #include #include #include using namespace std; typedef struct { int y, x; }Dir; Dir moveDir[4] = { {1, 0}, {-1, 0}, {0,..