반응형
문제 설명
정수 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 합니다.
#include <string>
#include <vector>
using namespace std;
int solution(int n, string control) {
int answer = 0;
for(int i=0; i<control.size(); i++){
char sel = control[i];
switch(sel){
case 'w':
n ++; break;
case 's':
n --; break;
case 'd':
n += 10; break;
case 'a':
n -= 10; break;
}
}
answer = n;
return answer;
}
다른버전
#include <string>
#include <vector>
#include <map>
using namespace std;
map <char, int> m = {{'w', 1}, {'s', -1}, {'d', 10}, {'a', -10}};
int solution(int n, string control) {
int answer = n;
for(char ch : control)
answer += m[ch];
return answer;
}
와.. 이거보고 놀랐다 이런식으로도 코드를 쓸수있구나 라는걸..많이 배워야겠다..
#include <string>
#include <vector>
#include <map>
using namespace std;
int solution(int n, string control) {
int answer = 0;
map <char, int> m = {{'w', 1}, {'s', -1}, {'d', 10}, {'a', -10}};
for(char con : control){
n += m[con];
}
answer = n;
return answer;
}
이건 참고하고 내가 만들어본 코드다. 앞으로 이런 방식도 많이 써 봐야겠다
foreach문이랑 map을 이용한 간단한 코드로.. 크..이게 코딩이지
반응형
'프로그래머스(코딩테스트 연습)' 카테고리의 다른 글
프로그래머스/C++ 수열과 구간 쿼리 3 (0) | 2023.09.27 |
---|---|
프로그래머스/C++ 수 조작하기 2 (0) | 2023.09.27 |
프로그래머스/C++ 마지막 두 원소 (0) | 2023.09.27 |
프로그래머스/C++ 원소들의 곱과 합 (0) | 2023.09.26 |
프로그래머스/C++ 등차수열의 특정한 항만 더하기 (0) | 2023.09.25 |