본문 바로가기
Algorithm 💫/Problem Solving

[프로그래머스] JadenCase 문자열 만들기 / C++ / level2

by 돼지고기맛있다 2021. 9. 7.
반응형

✏️ 문제 링크

https://programmers.co.kr/learn/courses/30/lessons/12951

 

코딩테스트 연습 - JadenCase 문자열 만들기

JadenCase란 모든 단어의 첫 문자가 대문자이고, 그 외의 알파벳은 소문자인 문자열입니다. 문자열 s가 주어졌을 때, s를 JadenCase로 바꾼 문자열을 리턴하는 함수, solution을 완성해주세요. 제한 조건

programmers.co.kr

 

 

✏️ 문제 설명

더보기

JadenCase란 모든 단어의 첫 문자가 대문자이고, 그 외의 알파벳은 소문자인 문자열입니다. 문자열 s가 주어졌을 때, s를 JadenCase로 바꾼 문자열을 리턴하는 함수, solution을 완성해주세요.

제한 조건

  • s는 길이 1 이상인 문자열입니다.
  • s는 알파벳과 공백문자(" ")로 이루어져 있습니다.
  • 첫 문자가 영문이 아닐때에는 이어지는 영문은 소문자로 씁니다. ( 첫번째 입출력 예 참고 )

입출력 예

s / return
"3people unFollowed me" "3people Unfollowed Me"
"for the last week" "For The Last Week"

 

✏️ 문제 풀이

1. 맨 첫번째 Char가 알파벳인 경우 대문자로 변환!

2. 맨 첫번재 단어가 아닌 그 이후의 단어들 중 첫 단어이면서 알파벳인 경우 대문자로 변환!

if((isalpha(s[i]) && s[i-1] == ' ')  || (isalpha(s[i]) && i==0))
	s[i]=(toupper(s[i]));

3. 그 외 나머지 경우에는 소문자로 변환해준다. 

else {
    s[i] = tolower(s[i]);  
}

 

✏️ 문제 코드 (C++)

#include <string>
#include <iostream>
#include <vector>

using namespace std;

string solution(string s) {
    string answer = "";
   
    for(int i=0; i<s.size(); i++){
        if((isalpha(s[i]) && s[i-1] == ' ')  || (isalpha(s[i]) && i==0)){
            s[i]=(toupper(s[i]));
        }else{
          s[i] = tolower(s[i]);  
        }
        
    }
    
    return s;
}

 

 

반응형

댓글