문제 설명
JadenCase란 모든 단어의 첫 문자가 대문자이고, 그 외의 알파벳은 소문자인 문자열입니다. 단, 첫 문자가 알파벳이 아닐 때에는 이어지는 알파벳은 소문자로 쓰면 됩니다. (첫 번째 입출력 예 참고) 문자열 s가 주어졌을 때, s를 JadenCase로 바꾼 문자열을 리턴하는 함수, solution을 완성해주세요.
문제 풀이
- 플래그를 설정하여 다음이 첫번째 문자임을 저장한다.
- 공백 문자를 만났을 때 플래그를 True 설정한다.
- 플래그가 활성화되었을 때
- 문자를 대문자로 변환 시도한다.
- 플래그를 False로 설정한다.
- 플래그가 활성화되지 않았을 때
- 문자를 소문자로 변환 시도한다.
- 결과값을 반환한다.
코드 작성
#include <string>
#include <vector>
#include <sstream>
using namespace std;
string solution(string s) {
bool IsFirst = true;
for (char& ch : s)
{
if (IsFirst)
{
IsFirst = false;
ch = toupper(ch);
}
else
{
ch = tolower(ch);
}
if (ch == ' ')
IsFirst = true;
}
return s;
}
'Algorithm > Practice' 카테고리의 다른 글
| [Algorithm] 피보나치 수 (0) | 2025.01.23 |
|---|---|
| [Algorithm] 이진 변환 반복하기 (0) | 2025.01.22 |
| [Algorithm] 최댓값과 최솟값 (0) | 2025.01.22 |
| [Algorithm] 신고 결과 받기 (0) | 2025.01.21 |
| [Algorithm] 공원 산책 (1) | 2025.01.20 |