Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | ||||
4 | 5 | 6 | 7 | 8 | 9 | 10 |
11 | 12 | 13 | 14 | 15 | 16 | 17 |
18 | 19 | 20 | 21 | 22 | 23 | 24 |
25 | 26 | 27 | 28 | 29 | 30 | 31 |
Tags
- 코딩테스트
- BFS
- 알고리즘
- 자료구조
- 파이썬
- DFS
- 재귀
- 블챌
- DP
- 구현
- CSS
- Express
- 그리디알고리즘
- 완전탐색
- 코테
- react
- DFS기초
- 그리디
- react-query
- 백준알고리즘
- 스택
- 백준
- JS
- django
- 코드트리
- 스택자료구조
- DFS활용
- 코딩테스트실력진단
- socket.io
- 문자열
Archives
- Today
- Total
꾸준하게 거북이처럼
부분집합구하기 - DFS 기초 본문
a = []
def DFS(n):
if n > 3:
for i in a:
print(i, end=' ')
print()
return
else:
a.append(n)
DFS(n+1)
a.pop()
DFS(n+1)
# ------^나의 풀이
def dfs(v):
if v == n + 1:
for i in range(1, n + 1):
if ch[i] == 1:
print(i, end= ' ')
print()
else:
ch[v] = 1
dfs(v + 1)
ch[v] = 0
dfs(v + 1)
if __name__ == "__main__":
n = int(input())
ch = [0] * (n + 1)
dfs(1)
# ------^정답 풀이
# 원소가 1 2 3인 집합의 부분집합 구하기.
# 나의 풀이 : append와 pop을 이용해서 문제를 풀었음. DFS를 이용한 부분집합은 재귀를 이용해서 왼쪽 노드
# 방향으로는 해당 원소를 포함, 오른쪽 방향으로는 해당원소를 포함하는 않는 방향으로 반복적으로 호출, 제일 큰
# 원소의 수보다 커질 때가 종료시점.
# 정답 풀이: 배열에 원소를 0 과 1을 할당해서 1일 때는 포함하고 0일 때는 포함하지 않는다는 뜻으로 배열을
# 이용한다.
'Algorithm 문제 & 공부 > DFS' 카테고리의 다른 글
중복순열 구하기 (0) | 2022.06.20 |
---|---|
바둑이 승차 - CutEdgeTech (0) | 2022.06.20 |
합이 같은 부분집합 - DFS기초 (0) | 2022.06.20 |
백준 14502 문제 - 연구소 (0) | 2022.05.27 |
DFS의 활용과 Backtracking(백트래킹) (0) | 2022.05.27 |
Comments