Scribbling

[Programmers] 네트워크 본문

Computer Science/Algorithms & Data Structures

[Programmers] 네트워크

focalpoint 2024. 6. 20. 14:33

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

 

프로그래머스

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

programmers.co.kr

 

1. Python

def solution(n, computers):
    visited = set()
    def dfs(i):
        if i in visited:
            return
        visited.add(i)
        for j in range(n):
            if computers[i][j] == 1:
                dfs(j)
    ret = 0
    for i in range(n):
        if i not in visited:
            dfs(i)
            ret += 1
    return ret

 

2. C++

void dfs(int n, const vector<vector<int>>& computers, set<int>& visited, int i) {
	if (visited.find(i) != visited.end()) return;
	visited.insert(i);
	for (int j=0; j<n; j++) {
		if (computers[i][j] == 1) {
			dfs(n, computers, visited, j);
		}
	}
}

int solution(int n, vector<vector<int>> computers) {
    int ret {0};
	set<int> visited;
	for (int i=0; i<n; i++) {
		if (visited.find(i) == visited.end()) {
			dfs(n, computers, visited, i);
			ret++;
		}
	}
	return ret;
}

 

'Computer Science > Algorithms & Data Structures' 카테고리의 다른 글

[Programmers] 단어 변환  (0) 2024.06.20
[Programmers] 게임 맵 최단거리  (0) 2024.06.20
[Programmers] 타겟 넘버  (0) 2024.06.20
[Programmers] 도둑질  (0) 2024.06.18
[Programmers] 사칙연산  (0) 2024.06.18