문제 설명
문자열 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를 통해 다시 풀어보는 것도 고민해볼 필요성이 있다.
'코딩테스트 연습(with java) > 프로그래머스' 카테고리의 다른 글
프로그래머스<시저 암호> (0) | 2022.06.29 |
---|---|
프로그래머스<이상한 문자 만들기> 다시 풀기 (0) | 2022.06.27 |
프로그래머스 <문자열 내림차순으로 배치하기> (0) | 2022.06.25 |
소수 찾기 (0) | 2022.06.23 |
프로그래머스<약수의 개수와 덧셈> (0) | 2022.06.20 |