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
- 알고리즘
- Algorithm
- cim
- softeer
- 탐욕법
- 스마트팩토리
- 소프티어
- alogorithm
- 백준
- 딥러닝
- 비전공자
- re_lunchu
- GAN
- 토이프로젝트
- Python
- 힙큐
- JavaScript
- Java
- Baekjoon
- 현대
- 파이썬
- heapq
- 자바
- MES
- 자바스크립트
- 그리디
- 현대자동차
- programmers
- cs공부
- 프로그래머스
Archives
- Today
- Total
eaz_coding
[Softeer] 순서대로 방문하기 본문
문제
요약
n*n 배열에서 m개의 위치를 차례대로 방문할 수 있는 경로의 개수는?
원본
https://softeer.ai/practice/6246
풀이
import sys
input = sys.stdin.readline
n, m = map(int, input().split())
arr = [list(map(int, input().split())) for _ in range(n)]
goals = []
for _ in range(m):
x, y = map(int, input().split())
goals.append((x-1, y-1))
answer = 0
d = [(-1,0), (1,0), (0,-1), (0,1)]
visited = [[0] * n for _ in range(n)]
def dfs(now, idx):
global answer
if now == goals[idx]:
if idx == m-1:
answer += 1
return
else:
idx += 1
x, y = now
visited[x][y] = 1
for dx, dy in d:
nx, ny = x+dx, y+dy
if 0 <= nx < n and 0 <= ny < n and arr[nx][ny] == 0 and visited[nx][ny] == 0:
dfs((nx, ny), idx)
visited[x][y] = 0
dfs(goals[0], 1)
print(answer)
'eaz_algorithm' 카테고리의 다른 글
[Softeer] 자동차 테스트 (0) | 2024.03.13 |
---|---|
[Softeer] 조립라인 (0) | 2024.03.12 |
[Baekjoon] 휴게소 세우기 (0) | 2024.03.08 |
[Softeer] 슈퍼컴퓨터 클러스터 (1) | 2024.03.07 |
[Softeer] 징검다리 (0) | 2024.03.06 |