Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
@@ -0,0 +1,33 @@
from collections import deque

dx = [0, 0, -1, 1]
dy = [-1, 1, 0, 0]


def BFS(x, y, visited, maps, n, m):
visited[x][y] = True
q = deque()
q.append((x, y))

while q:
x, y = q.popleft()
for i in range(4):
nx = x + dx[i]
ny = y + dy[i]
if nx < 0 or nx >= n or ny < 0 or ny >= m:
continue
if maps[nx][ny] != 0 and not visited[nx][ny]:
visited[nx][ny] = True
q.append((nx, ny))
maps[nx][ny] = maps[x][y] + 1
return maps[-1][-1] if maps[-1][-1] > 1 else -1


def solution(maps):
answer = 0
n = len(maps)
m = len(maps[0])
visited = [[False] * m for _ in range(n)]
answer = BFS(0, 0, visited, maps, n, m)

return answer
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
def solution(n, computers):
answer = 0
visited = [False for i in range(n)]
for i in range(n):
if visited[i] == False:
DFS(n, computers, i, visited)
answer += 1
return answer


def DFS(n, computers, i, visited):
visited[i] = True
for j in range(n):
if j != i and computers[i][j] == 1:
if visited[j] == False:
DFS(n, computers, j, visited)
Original file line number Diff line number Diff line change
@@ -0,0 +1,28 @@
from collections import deque


def solution(begin, target, words):
answer = 0
visited = [False for _ in range(len(words))]
q = deque()
q.append((begin, 0))

while q:
word, count = q.popleft()
if word == target:
answer = count
return answer
else:
for i in range(len(words)):
tempCount = 0
if visited[i] != True:
for j in range(len(word)):
if word[j] != words[i][j]:
tempCount += 1

if tempCount == 1:
count += 1
q.append((words[i], count))
visited[i] = True

return answer
Original file line number Diff line number Diff line change
@@ -0,0 +1,50 @@
from collections import deque
# ํ…Œ์ผ€ 1,2๋ฒˆ ์‹คํŒจ
# def solution(tickets):
# answer = []
# q=deque()
# tickets.sort(key=lambda x:x[1])
# visited=[False for _ in range(len(tickets))]
# for i in range(len(tickets)):
# if tickets[i][0]=='ICN':
# q.append((tickets[i][0],tickets[i][1]))
# visited[i]=True
# break

# while q:
# start,end =q.popleft()
# answer.append(start)
# for i in range(len(tickets)):
# if tickets[i][0]==end and visited[i]==False:
# q.append((tickets[i][0],tickets[i][1]))
# visited[i]=True
# break

# answer.append(end)
# return answer


def solution(tickets):
answer = []
graph = {}

for start, end in tickets:
if start in graph:
graph[start].append(end)
else:
graph[start] = [end]

for key in graph.keys():
graph[key].sort(reverse=True)

q = deque(["ICN"])

while q:
current = q[-1]
if current in graph and graph[current]:
q.append(graph[current].pop())
else:
# popleftํ•ด์„œ ๊ทธ๋ƒฅ ๋‹ด๋Š”๊ฒŒ ์•ˆ๋˜๋Š” ์˜ˆ์‹œ [["ICN","A"],["ICN","B"],["B","ICN"]]
answer.append(q.pop())
answer.reverse()
return answer
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
def solution(numbers, target):
n = len(numbers)
answer = 0

def dfs(idx, result):
if idx == n:
if result == target:
nonlocal answer
answer += 1
return
else:
dfs(idx+1, result+numbers[idx]) # ๊ทธ ๋‹ค์Œ๊ฐ’์„ ๋”ํ•˜๊ณ  ๋นผ๊ณ 
dfs(idx+1, result-numbers[idx])
dfs(0, 0)
return answer