-
[Programmers] Swift 알고리즘 | Lv.0 수 조작하기 1► Swift/Programmers 2024. 2. 23. 20:46반응형
🔒 문제 설명
정수 n과 문자열 control이 주어집니다. control은 "w", "a", "s", "d"의 4개의 문자로 이루어져 있으며, control의 앞에서부터 순서대로 문자에 따라 n의 값을 바꿉니다.
- "w" : n이 1 커집니다.
- "s" : n이 1 작아집니다.
- "d" : n이 10 커집니다.
- "a" : n이 10 작아집니다.
위 규칙에 따라 n을 바꿨을 때 가장 마지막에 나오는 n의 값을 return 하는 solution 함수를 완성해 주세요.
🔒 제한사항
- -100,000 ≤ n ≤ 100,000
- 1 ≤ control의 길이 ≤ 100,000
- control은 알파벳 소문자 "w", "a", "s", "d"로 이루어진 문자열입니다.
🔒 입출력 예
n control result 0 "wsdawsdassw" -1
🔒 입출력 예 설명
입출력 예 #1
- 수 n은 control에 따라 다음과 같은 순서로 변하게 됩니다.
- 0 → 1 → 0 → 10 → 0 → 1 → 0 → 10 → 0 → -1 → -2 → -1
- 따라서 -1을 return 합니다.
🔐 solution of mine
for문
String()
import Foundation func solution(_ n:Int, _ control:String) -> Int { var answer: Int = n for i in control { if(String(i) == "w"){ answer += 1 } else if(String(i) == "s"){ answer -= 1 } else if(String(i) == "d"){ answer += 10 } else{ answer -= 10 } } return answer } solution(0,"wsdawsdassw") //output: -1
🔐 solution of others
Tuple
String.reduce()
func solution(_ n:Int,_ control:String) -> Int { let op:[Character:Int] = ["w":1,"s":-1,"d":10,"a":-10] return control.reduce(n){$0+op[$1]!} } solution(0,"wsdawsdassw") //output: -1
🔐 solution of others
String.reduce()
import Foundation func solution(_ n: Int, _ control:String) -> Int { return control.reduce(n){acc, c in acc + ( c == "w" ? 1 : c == "s" ? -1 : c=="d" ? 10 : -10) } } solution(0,"wsdawsdassw") //output: -1
반응형'► Swift > Programmers' 카테고리의 다른 글
[Programmers] Swift 알고리즘 | Lv.0 두 수의 연산값 비교하기 (0) 2024.02.28 [Programmers] Swift 알고리즘 | Lv.0 뒤에서 5등까지 (0) 2024.02.23 [Programmers] Swift 알고리즘 | Lv.0 대문자로 바꾸기 (0) 2024.02.22 [Programmers] Swift 알고리즘 | Lv.0 길이에 따른 연산 (0) 2024.02.22 [Programmers] Swift 알고리즘 | Lv.0 카운트 업 (0) 2024.02.22