728x90
반응형
문제 설명
정수 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 합니다.
내 풀이
Java
class Solution {
public int solution(int n, String control) {
int answer = n;
for(int i = 0; i < control.length(); i++){
switch(control.charAt(i)){
case 'w':
answer++;
break;
case 's':
answer--;
break;
case 'd':
answer += 10;
break;
case 'a':
answer -= 10;
break;
}
}
return answer;
}
}
C
#include <stdio.h>
#include <stdbool.h>
#include <stdlib.h>
// 파라미터로 주어지는 문자열은 const로 주어집니다. 변경하려면 문자열을 복사해서 사용하세요.
int solution(int n, const char* control) {
int answer = n;
int i;
for(i = 0; i < strlen(control); i++){
if(control[i] == 'w'){
answer++;
}else if(control[i] == 's'){
answer--;
}else if(control[i] == 'd'){
answer += 10;
}else{
answer -= 10;
}
}
return answer;
}
Python
def solution(n, control):
answer = n
for s in control:
if s == 'w':
answer += 1
elif s == 's':
answer -= 1
elif s == 'd':
answer += 10
else:
answer -= 10
return answer
https://school.programmers.co.kr/learn/courses/30/lessons/181926
프로그래머스
SW개발자를 위한 평가, 교육, 채용까지 Total Solution을 제공하는 개발자 성장을 위한 베이스캠프
programmers.co.kr
[코딩테스트 Lv.0] 수 조작하기 2
문제 설명정수 배열 numLog가 주어집니다. 처음에 numLog[0]에서 부터 시작해 "w", "a", "s", "d"로 이루어진 문자열을 입력으로 받아 순서대로 다음과 같은 조작을 했다고 합시다."w" :
bluedayj.tistory.com
728x90
반응형
'코딩테스트 > 프로그래머스 기초' 카테고리의 다른 글
[코딩테스트 Lv.0] 이어 붙인 수 (4) | 2025.04.01 |
---|---|
[코딩테스트 Lv.0] 마지막 두 원소 (6) | 2025.03.31 |
[코딩테스트 Lv.0] 수 조작하기 2 (3) | 2025.03.29 |
[코딩테스트 Lv.0] 수열과 구간 쿼리 3 (7) | 2025.03.28 |
[코딩테스트 Lv.0] 수열과 구간 쿼리 2 (10) | 2025.03.27 |