문제 : JadenCase 문자열 만들기
문제 설명
JadenCase란 모든 단어의 첫 문자가 대문자이고, 그 외의 알파벳은 소문자인 문자열입니다. 문자열 s가 주어졌을 때, s를 JadenCase로 바꾼 문자열을 리턴하는 함수, solution을 완성해주세요.
제한 조건
- s는 길이 1 이상인 문자열입니다.
- s는 알파벳과 공백문자(" ")로 이루어져 있습니다.
- 첫 문자가 영문이 아닐때에는 이어지는 영문은 소문자로 씁니다. ( 첫번째 입출력 예 참고 )
입출력 예
s | return |
3people unFollowed me | 3people Unfollowed Me |
for the last week | For The Last Week |
분석
규칙이 간결하다. 조건문만 잘사용해서 처리하자.
구현
using namespace std;
string solution(string s)
{
string answer = s;
bool change = true;
for (int i = 0; i < answer.size(); i++)
{
if (answer[i] == ' ')
{
change = true;
}
else if (change && 'a' <= answer[i] <= 'z')
{
answer[i] = toupper(answer[i]);
change = false;
}
else if (!change && 'A' <= answer[i] <= 'Z')
{
answer[i] = tolower(answer[i]);
}
}
return answer;
}
int main()
{
cout << solution("3people unFollowed me"); // 3people Unfollowed Me
return 0;
}
'알고리즘 > 프로그래머스' 카테고리의 다른 글
[프로그래머스 C++] 짝지어 제거하기 (0) | 2021.02.16 |
---|---|
[프로그래머스 C++] N개의 최소공배수 (0) | 2021.02.15 |
[프로그래머스 C++] 행렬의 곱셈 (0) | 2021.02.13 |
[프로그래머스 C++] 피보나치 수 (0) | 2021.02.12 |
[프로그래머스 C++] 최솟값 만들기 (0) | 2021.02.11 |