너굴 개발 일지

[Algorithm] 프로그래머스 이상한 문자 만들기 (Java) 본문

혼자 공부,정리하는 알고리즘

[Algorithm] 프로그래머스 이상한 문자 만들기 (Java)

너굴냥 2021. 10. 12. 21:37

[문제]

 

문자열 s는 한 개 이상의 단어로 구성되어 있습니다. 각 단어는 하나 이상의 공백문자로 구분되어 있습니다. 각 단어의 짝수번째 알파벳은 대문자로, 홀수번째 알파벳은 소문자로 바꾼 문자열을 리턴하는 함수, solution을 완성하세요.

 

제한사항

 

  • 문자열 전체의 짝/홀수 인덱스가 아니라, 단어(공백을 기준)별로 짝/홀수 인덱스를 판단해야합니다.
  • 첫 번째 글자는 0번째 인덱스로 보아 짝수번째 알파벳으로 처리해야 합니다.

입출력 예

입력  출력
"try hello world" "TrY HeLlO WoRlD"

 

입출력 예 설명

"try hello world"는 세 단어 "try", "hello", "world"로 구성되어 있습니다. 각 단어의 짝수번째 문자를 대문자로, 홀수번째 문자를 소문자로 바꾸면 "TrY", "HeLlO", "WoRlD"입니다. 따라서 "TrY HeLlO WoRlD" 를 리턴합니다.

 

[풀이]

문제는 간단하다. 공백을 기준으로 문자의 인덱스가 홀/짝의 여부를 판단하고 그에 따라 짝수번째 인덱스면 대문자로, 홀수번째 인덱스는 소문자로 바꿔서 반환하면 된다. 그리고 0번째 문자는 대문자로 바꿔줘야 하므로 각 문자열들은 짝/홀/짝/홀/짝/홀.. 이런식으로 구분하면 된다.

boolean 변수가 true라면 대문자, false라면 소문자로 바꿔줬고, 만약 해당 문자열이 공백(' ')이라면 boolean 을 다시 true로 변경하였다. 왜냐하면 공백으로 문자열이 구분되기에 공백 뒤 문자열은 0번째 시작으로 대문자로 변경해야 하기 때문이다.

 

[설명]

class Solution {
  public String solution(String str) {
        boolean flag = false;
		String answer = "";
		
		for(int i=0; i <str.length();i++) {
			if(str.charAt(i) == ' ') {
				answer += " ";
				flag = true;
				continue;
			}
			String tmp ="";
			if(flag == true) {	// 짝수일경우
				tmp = ""+str.charAt(i);
				answer +=tmp.toUpperCase();
				flag = true;
			}else if(flag == false) {	// 홀수일경우
				tmp = ""+str.charAt(i);
				answer +=tmp.toLowerCase();
				flag = false;
			}
		}
      return answer;
  }
}