[프로그래머스/Java] Lv.0 수 조작하기 1

febCho·2024년 3월 3일
0

코딩테스트

목록 보기
27/253
post-thumbnail

문제

정수 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"로 이루어진 문자열입니다.

풀이

- 오답

if ~ else if를 사용하자니 조건문에서 equals()를 일일이 써야 했다. 코드가 너무 길어지는 걸 원치 않아 switch문을 사용해 해결했다.

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

결과

결과

profile
Done is better than perfect.

0개의 댓글