morenow
morenow
morenow
전체 방문자
오늘
어제
  • 분류 전체보기 (83)
    • 스프링부트와 AWS로 혼자 구현하는 웹 서비스 (5)
    • [MSA] Spring Cloud로 개발하는 마이.. (14)
    • Baekjoon Online Judge (40)
    • Programmers (11)
    • Spring Boot (7)

블로그 메뉴

  • 홈
  • 태그
  • 방명록

공지사항

인기 글

태그

  • lost update
  • dirty write
  • copy up
  • HTTP Interface
  • Id Token
  • JWT단점
  • successHandler
  • Refresh Token Refresh
  • write skew
  • 마법사 상어와 파이어스톰
  • B+ Tree
  • HttpExchange
  • 백준 파이어스톰
  • 백준20058C++
  • B Tree
  • jwt
  • Spring Boot
  • re-distribution
  • Feign Client
  • Open Feign

최근 댓글

최근 글

티스토리

hELLO · Designed By 정상우.
morenow

morenow

Programmers

[Programmers] 네트워크 (C++)

2023. 10. 12. 13:42

https://school.programmers.co.kr/learn/courses/30/lessons/43162

 

프로그래머스

코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.

programmers.co.kr

걸린 시간 : 8분 50초


알고리즘

간단한 BFS 혹은 DFS 문제이다.

이 문제는 어떤 것으로 풀어도 나쁘지 않지만, 코드 구현은 BFS보다 재귀를 사용하는 DFS가 간단한다.

방문체크는 vis라는 배열로 처리하고, 방문하지 않은 노드를 발견하면 카운트를 하고 DFS를 실행하면 끝이다.

정답 코드

#include <string>
#include <vector>

using namespace std;

bool vis[201];

void dfs(int i, vector<vector<int>>& computers) {
    vis[i] = true;
    for (int j = 0; j < computers.size(); j++) {
        if (!vis[j] && computers[i][j]) {
            dfs(j, computers);
        }
    }
}

int solution(int n, vector<vector<int>> computers) {
    int answer = 0;
    for (int i = 0; i < computers.size(); i++) {
        if (vis[i]) continue;
        answer++;
        dfs(i, computers);
    }
    return answer;
}

'Programmers' 카테고리의 다른 글

[Programmers] 야근 지수 (Java)  (1) 2023.11.16
[Programmers] 2023 KAKAO BLIND RECRUITMENT : 택배 배달과 수거하기 (Java)  (0) 2023.10.18
[Programmers] 정수 삼각형 (C++)  (0) 2023.10.12
[Programmers] JadenCase (C++)  (0) 2023.10.12
[Programmers] 최댓값과 최솟값 (C++) with 문자열 파싱 (토큰 분리)  (0) 2023.10.08
    'Programmers' 카테고리의 다른 글
    • [Programmers] 야근 지수 (Java)
    • [Programmers] 2023 KAKAO BLIND RECRUITMENT : 택배 배달과 수거하기 (Java)
    • [Programmers] 정수 삼각형 (C++)
    • [Programmers] JadenCase (C++)
    morenow
    morenow

    티스토리툴바