📢 문제 출처
⏰ 문제 설명
- 정수 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 함수를 완성해 주세요.
⏰ 입출력 예시
- 입출력 예 #1
- (1). 수 n은 control에 따라 다음과 같은 순서로 변하게 됩니다.
- (2). 0 → 1 → 0 → 10 → 0 → 1 → 0 → 10 → 0 → -1 → -2 → -1
- (3). 따라서 -1을 Return 합니다.
⏰ 풀이
class Solution {
public int solution(int n, String control) {
int answer = 0;
String[] controlList = control.split("");
for(int i=0;i<controlList.length;i++)
{
if(controlList[i].contains("w")){
n +=1;
}
else if(controlList[i].contains("s")){
n -=1;
}
else if(controlList[i].contains("d")){
n +=10;
}
else if(controlList[i].contains("a")){
n -=10;
}
}
return n;
}
}
- control의 문자열을 하나씩 나누어서 값을 구해야 하기 때문에
- String[] 하나 선언하여 split("") 진행하여 배열을 만든다.
- 배열 안의 인덱스 갯수 대로 for문을 돌려서 해당 Stiring 배열에 "w", "a", "s", "d" 가 있는 경우 해당 연산을 진행한다.
⏰ 다른 풀이
class Solution {
public int solution(int n, String control) {
for (char ch : control.toCharArray()) {
if (ch == 'w') n += 1;
else if (ch == 's') n -= 1;
else if (ch == 'd') n += 10;
else n -= 10;
}
return n;
}
}
- String.toCharArray() 는 문자열을 한 글자씩 쪼개서 이를 char타입의 배열에 집어넣어주는 친절한 메소드이다.
- char형으로 String을 하나씩 구분을 짓고 해당 문자가 for문을 돌면서 조건에 맞으면 수식을 진행하는 방식이다.
반응형
'코딩테스트 > 프로그래머스' 카테고리의 다른 글
[프로그래머스] 뒤에서 5등까지 (0) | 2023.08.05 |
---|---|
[프로그래머스] 부분 문자열인지 확인하기 (0) | 2023.08.05 |
[ 프로그래머스] 꼬리 문자열 (0) | 2023.08.05 |
댓글