본문 바로가기

코딩테스트 연습(with java)/프로그래머스

프로그래머스<이상한 문자 만들기>

문제 설명

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

제한 사항
  • 문자열 전체의 짝/홀수 인덱스가 아니라, 단어(공백을 기준)별로 짝/홀수 인덱스를 판단해야합니다.
  • 첫 번째 글자는 0번째 인덱스로 보아 짝수번째 알파벳으로 처리해야 합니다.
입출력 예
s                                                                                     return
"try hello world" "TrY HeLlO WoRlD"
입출력 예 설명

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

 

//차선책 1번 그냥 Uppercase, Lowercase를 사용해야할까 ?
import java.util.*;
class Solution {
    public String solution(String s) {
        
        //답으로 출력할 문자들을 이어붙이기 위해 StringBuffer()생성
        StringBuffer sb = new StringBuffer();
        //문자열을 배열로 생성(char형) 
        char[] arr = s.toCharArray();
        //(배열을 돌며 아스키형 코드로 변환 )
        for(int i =0; i<arr.length; i++){
            char character = arr[i];
            int ascii = (int) character;
        //짝수번째 인덱스는 소문자를 대문자로 변환시키 때문에 아스키코드값을 32씩 뺴준다 
            if(i%2==0){
                ascii = ascii-32;
                character = (char)ascii;
                sb.append(String.valueOf(character));    
            }
        //홀수는 그냥 출력한다  
            else{
                sb.append(String.valueOf(character));
            }
        }  
        String answer = sb.toString();
        return answer;
    }
}

 

테스트 케이스는 통과했는데, 정답제출 시 모든 부분에서 불합격이 떴다. 대체 왜인지 모르겠어서, Uppercase나 Lowercase를 통해 다시 풀어보는 것도 고민해볼 필요성이 있다.