일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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
- Java
- 코딩테스트
- SWIFT
- cocoapods
- swiftUI
- pod install
- ios15
- Kotlin
- MapKit
- UserDefaults
- Alert
- Appearance변경
- ios
- segue
- image
- UIStackView
- snapkit
- AsyncImage
- EventKit
- CoreLocation
- alamofire
- kakaomap
- 백준
- SwiftUI_Preview_Provider
- format형식
- NotificationCenter
- android
- programmers
- autolayout
- ViewModifier
Archives
- Today
- Total
감자주먹밥
[프로그래머스] 기능개발 (swift) 본문
728x90
문제
문제 해결
- progresses 배열이 없어질 때 까지 반복을 한다.
- 첫 번째 element가 100 미만이면 진행도를 더해주고, count를 확인해 1이상이면 answer에 추가한다.
- 만약 100이상이라면 큐 처럼 가장 앞 원소를 삭제하고 count를 하나 늘린다.
- 위 작업을 반복하다 하나만 남았을 때 count만 올리고 나가지게 된다. 그러므로 바깥쪽에 count를 확인해 추가를 해 준다.
코드
func solution(_ progresses:[Int], _ speeds:[Int]) -> [Int] {
var pro = progresses
var spd = speeds
var count = 0
var answer: [Int] = []
while (!pro.isEmpty) {
if (pro.first! < 100) {
for index in 0..<pro.count { //하루 지날 때 마다 진행
pro[index] += spd[index]
}
if count > 0 {
answer.append(count)
count = 0
}
}
else {
pro.removeFirst()
spd.removeFirst()
count+=1
}
}
if count > 0 {
answer.append(count)
}
return answer
}
문제 해결 중 어려웠던 것
진행도를 더하고, 맨 앞이 100 이상이면 없애주면서 count 처리를 해 만들려고 했는데...
기본적인 로직을 짜는데 문제가 있었다. 반복문에서 하나를 마지막에 처리하지 못하는 걸 간과하여 시간이 걸렸다.
다른방식
프로그래머스 알고리즘, 기능개발 swift 배열큐 문제풀이
먼저 개발 일 수를 구하고 처리하는 방식으로 해결하셨다.
O(n^2) 방식과 O(n)방식이 있으니 다시 확인해보기
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