일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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
- 재귀
- 정렬 알고리즘
- HTML
- LoB
- c언어
- windosw 문자열
- OSI
- 파이썬
- 파일 시스템
- 백준
- PHP
- 시간복잡도
- System
- Stack
- 암호수학
- ftz level13
- 스택
- 자료구조
- 미로 탐색 알고리즘
- 두근두근 자료구조
- ftz
- Java
- SWiFT
- level13
- War Game
- C
- web
- 큐
- windosws wbcs
- pwnable.kr
Archives
- Today
- Total
나의 기록, 현진록
[Swift] Data Structure/maze search/BFS/queue/미로 탐색/너비우선탐색/큐 본문
Programming/Algorithm & Data Structure
[Swift] Data Structure/maze search/BFS/queue/미로 탐색/너비우선탐색/큐
guswlsdk 2021. 6. 30. 11:12반응형
문제 설명
var map = [
["1","1","1","1","1","1"],
["e","0","1","0","0","1"],
["1","0","0","0","1","1"],
["1","0","1","0","1","1"],
["1","0","1","0","0","x"],
["1","1","1","1","1","1"]]
현재 위치가 "e"일 때 "x"까지 도달하는 프로그램을 작성해야 한다.
"1"은 이동할 수 없는 길이며, "0"인 길로만 이동할 수 있다.
맵은 2차원 배열로 작성되어 있으며 BFS(너비 우선 탐색) 알고리즘과 Queue 자료구조를 활용하여 해결할 것이다.
해결 방안
- 현재 위치 저장하기
- 현재 위치를 "0"이 아닌 다른 값으로 변경하여 지나온 길 표시하기 -> 필자는 "e"로 변경함
- 현재 위치에서 이동 가능한 경로 큐에 삽입하기
- 큐에 있는 경로로 이동하기
- 2~4 과정을 현재 위치가 "x"일 때까지 반복하기
import Foundation
var map = [
["1","1","1","1","1","1"],
["e","0","1","0","0","1"],
["1","0","0","0","1","1"],
["1","0","1","0","1","1"],
["1","0","1","0","0","x"],
["1","1","1","1","1","1"]]
struct Location {
var x: Int
var y: Int
init(_ x : Int, _ y : Int) {
self.x = x
self.y = y
}
}
func searchPath(){
print(cur.y, cur.x)
map[cur.y][cur.x] = "e"
//search left
if cur.x-1>=0{
if map[cur.y][cur.x-1] == "0" || map[cur.y][cur.x-1] == "x"{
stack.append(Location(cur.x-1, cur.y))
}
}
//search down
if cur.y-1>=0{
if map[cur.y-1][cur.x] == "0" || map[cur.y-1][cur.x] == "x"{
stack.append(Location(cur.x, cur.y-1))
}
}
//search right
if cur.x+1 <= map.count-1{
if map[cur.y][cur.x+1] == "0" || map[cur.y][cur.x+1] == "x"{
stack.append(Location(cur.x+1, cur.y))
}
}
//search up
if cur.y+1 <= map.count-1{
if map[cur.y+1][cur.x] == "0" || map[cur.y+1][cur.x] == "x"{
stack.append(Location(cur.x, cur.y+1))
}
}
}
func readQueue(){
if stack.count != 0{
cur.x = stack[0].x
cur.y = stack[0].y
stack.removeFirst()
}
}
var stack: [Location] = []
var cur = Location(0, 1)
while map[cur.y][cur.x] != "x"{
searchPath()
readQueue()
}
print(map[cur.y][cur.x])
DFS로 구현한 것보다 더 오래 걸린다.............
구현을 마치고...
큐로 구현한 것 또한 현재 위치에서 경로 탐색 순서를 어떻게 정하느냐에 따라 프로그램 시간이 좌우될 것이다.
반응형
'Programming > Algorithm & Data Structure' 카테고리의 다른 글
[Swift] Data Structure recursion / divide and conquer, D&C / 자료구조 순환, 재귀 / 분할정복 (0) | 2021.07.06 |
---|---|
[Swift] 백준 1012 유기농 배추 / DFS (0) | 2021.06.30 |
[Swift] Data Structure/maze search/DFS/stack/미로 탐색/깊이우선탐색/스택 (0) | 2021.06.30 |
[Swift] Data Structure Circle Deque 자료구조 원형 덱 (0) | 2021.06.30 |
[Swift] Data Structure Linear Deque 자료구조 선형 덱 (0) | 2021.06.24 |