일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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
- NotificationCenter
- autolayout
- EventKit
- AsyncImage
- programmers
- Alert
- SWIFT
- image
- snapkit
- 코딩테스트
- CoreLocation
- 백준
- Java
- ios15
- cocoapods
- SwiftUI_Preview_Provider
- Appearance변경
- ViewModifier
- ios
- Kotlin
- swiftUI
- UserDefaults
- UIStackView
- alamofire
- android
- MapKit
- pod install
- format형식
- kakaomap
- segue
Archives
- Today
- Total
감자주먹밥
[프로그래머스] 프린터 (swift) 본문
728x90
문제
문제 해결
- 프린터 풀에서 최대 중요도 수를 가져온다.
- 프린터 풀 앞에서 부터 최대 중요도 수를 체크한다.
- 같다면 풀에 값을 삭제하고 max를 갱신시킨다. 출력 카운트를 늘리고, 요청 문서 위치를 갱신한다.
- 다르다면 뒤로 보내는 작업을 한 후, 요청한 문서의 위치를 갱신시킨다.
- 마지막으로 요청한 문서가 출력되면 position은 -1이 되어 반복문을 빠져 나오고 값을 출력한다.
코드
func solution(_ priorities:[Int], _ location:Int) -> Int {
var position = location
var pool = priorities
var max = pool.max()
var count = 0
while !pool.isEmpty && position >= 0 {
if max != pool.first {
pool.append(pool.first!)
pool.removeFirst()
if position == 0 {
position = pool.count-1
}
else { position -= 1 }
}
else {
pool.removeFirst()
max = pool.max()
count+=1;
position -= 1
}
}
return count
}
문제 해결 중 어려웠던 것
문제를 풀면서 생각을 너무 안하고 풀었다..
플래그만 몇가지 만들어서 해결한 문제치고 간단하게 풀긴 했지만
공간 복잡도, 시간 복잡도를 생각하고 문제를 푸는 방식을 고려해야겠다.
0.90ms가 최저 속도, 메모리는 평균 16.6MB 정도 사용됐다.
다른방식
func solution(_ priorities:[Int], _ location:Int) -> Int {
var cPriorities = priorities
var targetIndex = location
var seq = 0
while cPriorities.count > 0 {
if cPriorities.contains(where: { $0 > cPriorities[0] }) {
let first = cPriorities.removeFirst()
cPriorities.append(first)
targetIndex = targetIndex - 1 < 0 ? cPriorities.count - 1 : targetIndex - 1
} else {
if(targetIndex == 0) {
return priorities.count - cPriorities.count + 1
}
cPriorities.removeFirst()
targetIndex = targetIndex - 1
}
}
return 0
}
728x90
'알고리즘 > 프로그래머스' 카테고리의 다른 글
[프로그래머스] 체육복 (swift) (0) | 2021.12.18 |
---|---|
[프로그래머스] 기능개발 (swift) (0) | 2021.12.18 |
[프로그래머스] H-Index (swift) (0) | 2021.12.18 |
[프로그래머스] 가장 큰 수 (swift) (0) | 2021.12.18 |
[프로그래머스] K번째 수 (swift) (0) | 2021.12.18 |
Comments