Skip to content

Latest commit

 

History

History
54 lines (40 loc) · 1.52 KB

File metadata and controls

54 lines (40 loc) · 1.52 KB

수 조작하기 1

📌 문제 설명

정수 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

🧐 접근

switch문 사용

class Solution {
    public int solution(int n, String control) {
        for (char c : control.toCharArray()) {
            switch(c) {
                    case 'w' -> n += 1;
                    case 's' -> n -= 1;
                    case 'd' -> n += 10;
                    case 'a' -> n -= 10;
                    default -> {}
            }
        }
        return n;
    }
}

💡 풀이

주어진 문자열을 문자형배열로 변환하여 iter문을 수행한다. iter문 내에서 switch문을 사용하여 각 조건에 부합하는 연산식을 수행한다. Java17에서 생긴 새로운 패턴의 switch문으로 작성해보았다.

📘 그 외의 풀이

==================