Algorithm/BOJ

[알고리즘/백준/13023] ABCDE(Node.js, BFS)

2023. 8. 24. 17:47
목차
  1. 문제
  2.  
  3. 풀이
반응형

문제


https://www.acmicpc.net/problem/13023

 

13023번: ABCDE

문제의 조건에 맞는 A, B, C, D, E가 존재하면 1을 없으면 0을 출력한다.

www.acmicpc.net

 

풀이


문제를 읽고 숫자고르기와 같이 각 요소에서 DFS 탐색을 해야 한다는 걸 알 수 있었다.

주어진 입력으로 양방향 그래프를 만들고, 각 1~N에서 각각 방문 표시 배열(ch)을 이용한 DFS를 한다.

이때 flag 변수를 사용하여 연결된 노드가 5개가 나오는 경우 return 해서 DFS를 종료한다.

또한 flag가 1인 경우, 즉 A, B, C, D, E가 존재하는 경우, for문을 종료한다. flag가 1이면 1을 아니면 0을 출력한다. 

 

처음에는 DFS에서 연결된 개수를 반환해주고, 다 돌고 나왔을 때 그 개수가 5개라면 1 아니면 0을 반환하면 된다고 생각했다.

그래서 처음에는 DFS 값을 계속 반환해서 올려줬는데, 그랬더니 DFS에서 나왔을 때 방문표시를 풀어줄 수 없었다.(ch[nx] = 0)

각 노드 i에서 연결된 노드 nx를 탐색할 때 이전 nx에서 탐색했던 노드들은 방문 표시를 풀어줘야한다. 

const fs = require("fs");
const filePath = process.platform === "linux" ? "/dev/stdin" : "./input.txt";
let [n, ...arr] = fs.readFileSync(filePath).toString().trim().split("\n");

const [N, M] = n.split(" ").map(Number);
const map = arr.map((row) => row.split(" ").map(Number));
let flag = 0;
const graph = Array.from({ length: N }, () => []);
for (let [from, to] of map) {
  graph[from].push(to);
  graph[to].push(from);
}

let ch;

function DFS(i, cnt) {
  if (cnt >= 5) {
  	// 5개 이상 연결되어 있는 경우 ABCDE 존재 O
    flag = 1;
    return;
  } else {
    for (let k = 0; k < graph[i].length; k++) {
      const nx = graph[i][k];

      if (ch[nx] === 0) {
        ch[nx] = 1;
        DFS(nx, cnt + 1);
        ch[nx] = 0; 
      }
    }
  }
}

// 각 숫자에서 DFS
for (let i = 0; i < N; i++) {
  ch = Array.from({ length: N }).fill(0);

  ch[i] = 1;
  DFS(i, 1);

  if (flag) break;
}

console.log(flag ? 1 : 0);

 

반응형
저작자표시 (새창열림)

'Algorithm > BOJ' 카테고리의 다른 글

[알고리즘/백준/2636] 치즈(Nodejs, BFS)  (1) 2023.08.31
[알고리즘/백준/14502] 연구소(BFS, DFS, Nodejs)  (0) 2023.08.26
[알고리즘/백준/16234] 인구 이동(BFS, Node.js)  (0) 2023.08.23
[알고리즘/백준/2668] 숫자고르기(Nodejs, DFS)  (0) 2023.08.01
[알고리즘/백준/17836] 공주님을 구해라!(BFS, Nodejs)  (1) 2023.07.04
  1. 문제
  2.  
  3. 풀이
'Algorithm/BOJ' 카테고리의 다른 글
  • [알고리즘/백준/2636] 치즈(Nodejs, BFS)
  • [알고리즘/백준/14502] 연구소(BFS, DFS, Nodejs)
  • [알고리즘/백준/16234] 인구 이동(BFS, Node.js)
  • [알고리즘/백준/2668] 숫자고르기(Nodejs, DFS)
개발자 김비숑
개발자 김비숑
프론트엔드 개발자를 준비하고 있는 김비숑입니다.
반응형
개발자 김비숑
김비숑과 프론트엔드
개발자 김비숑
전체
오늘
어제
  • 분류 전체보기 (118)
    • FrontEnd (24)
      • HTML&CSS (1)
      • JavaScript (3)
      • TypeScript (8)
      • React (8)
      • Test (4)
    • CS (1)
    • Algorithm (83)
      • BOJ (42)
      • Inflearn (26)
      • Programmers (15)
    • Git (0)
    • Projects (4)
    • Translation (1)
    • Others (0)
      • Reviews (4)
      • About Me (0)

블로그 메뉴

  • 홈
  • 태그
  • 방명록
  • 글쓰기

인기 글

최근 글

hELLO · Designed By 정상우.
개발자 김비숑
[알고리즘/백준/13023] ABCDE(Node.js, BFS)
상단으로

티스토리툴바

단축키

내 블로그

내 블로그 - 관리자 홈 전환
Q
Q
새 글 쓰기
W
W

블로그 게시글

글 수정 (권한 있는 경우)
E
E
댓글 영역으로 이동
C
C

모든 영역

이 페이지의 URL 복사
S
S
맨 위로 이동
T
T
티스토리 홈 이동
H
H
단축키 안내
Shift + /
⇧ + /

* 단축키는 한글/영문 대소문자로 이용 가능하며, 티스토리 기본 도메인에서만 동작합니다.