수 조작하기1

안시우·2024년 4월 21일

프로그래머스

목록 보기
2/4

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 함수를 완성해 주세요.

2. 제한사항

-100,000 ≤ n ≤ 100,000
1 ≤ control의 길이 ≤ 100,000
control은 알파벳 소문자 "w", "a", "s", "d"로 이루어진 문자열입니다.

3. 입출력 예

n 0 result
0 "wsdawsdassw" -1

4. Solution

class Solution {
    public int solution(int n, String control) {
        String[] list = control.split("");
        for (int i=0;i<list.length;i++) {
            switch (list[i]) {
            case "w": n += 1; break;
            case "s": n -= 1; break;
            case "d": n += 10; break;
            case "a": n -= 10; break;
        }
        }
        return n;
    }
}

5. 풀이

  • switch case문을 이용하여 조건을 설정하였습니다.
  • 추가 : control의 문자를 조건과 비교할 때, toCharArray를 이용해 보는 것도 좋을 것 같습니다.

참고

https://school.programmers.co.kr/learn/courses/30/lessons/181926

0개의 댓글