프로그래머스 1단계 Java 이상한 문자 만들기 문제입니다.
문제 설명
문자열 s는 한 개 이상의 단어로 구성되어 있습니다. 각 단어는 하나 이상의 공백문자로 구분되어 있습니다. 각 단어의 짝수번째 알파벳은 대문자로, 홀수번째 알파벳은 소문자로 바꾼 문자열을 리턴하는 함수, solution을 완성하세요.
제한 사항
- 문자열 전체의 짝/홀수 인덱스가 아니라, 단어(공백을 기준)별로 짝/홀수 인덱스를 판단해야합니다.
- 첫 번째 글자는 0번째 인덱스로 보아 짝수번째 알파벳으로 처리해야 합니다.
입출력 예
s | return |
"try hello world" | "TrY HeLlO WoRlD" |
입출력 예 설명
"try hello world"는 세 단어 "try", "hello", "world"로 구성되어 있습니다. 각 단어의 짝수번째 문자를 대문자로, 홀수번째 문자를 소문자로 바꾸면 "TrY", "HeLlO", "WoRlD"입니다. 따라서 "TrY HeLlO WoRlD" 를 리턴합니다.
문제 해결 방법
① 문자열 s의 첫번째 문자부터 마지막 문자까지 비교
⑴ 문자인 경우 ▶ 대소문자 플래그 비교(첫번째 문자는 대문자)
⒜ 대문자 순서인 경우 ▶ 대문자로 변환 후 반환할 문자열에 대입, 대소문자 플래그 값을 소문자로 변경
⒝ 소문자 순서인 경우 ▶ 소문자로 변환 후 반환할 문자열에 대입, 대소문자 플래그 값을 대문자로 변경
⑵ 공백인 경우 ▶ 반환할 문자열에 공백 대입 후, 대소문자 플래그 값 초기화(대문자)
class Solution {
public String solution(String s) {
String answer = "";
boolean upperFlag = true;
// ① 문자열 s의 첫번째 문자부터 마지막 문자까지 비교
for(int i = 0; i < s.length(); i++){
// ⑴ 문자인 경우 ▶ 대소문자 플래그 비교(첫번째 문자는 대문자)
if(s.charAt(i) != ' ') {
// ⒜ 대문자 순서인 경우 ▶ 대문자로 변환 후 반환할 문자열에 대입, 대소문자 플래그 값을 소문자로 변경
// ⒝ 소문자 순서인 경우 ▶ 소문자로 변환 후 반환할 문자열에 대입, 대소문자 플래그 값을 대문자로 변경
answer += upperFlag ? Character.toUpperCase(s.charAt(i)) : Character.toLowerCase(s.charAt(i));
upperFlag = !upperFlag;
}
else {
// ⑵ 공백인 경우 ▶ 반환할 문자열에 공백 대입 후, 대소문자 플래그 값 초기화(대문자)
answer += s.charAt(i);
upperFlag = true;
}
}
return answer;
}
}
※ 위 코드는 해결 방법 중 한가지이며 더 효율적인 코드가 있을 수 있습니다.
문제 풀어보기 ▶ https://programmers.co.kr/learn/courses/30/lessons/12930?language=java
코딩테스트 연습 - 이상한 문자 만들기
문자열 s는 한 개 이상의 단어로 구성되어 있습니다. 각 단어는 하나 이상의 공백문자로 구분되어 있습니다. 각 단어의 짝수번째 알파벳은 대문자로, 홀수번째 알파벳은 소문자로 바꾼 문자열을
programmers.co.kr
'programmers code review > _step1' 카테고리의 다른 글
시저 암호 (0) | 2021.08.17 |
---|---|
약수의 합 (0) | 2021.08.17 |
자릿수 더하기 (0) | 2021.08.17 |
자연수 뒤집어 배열로 만들기 (0) | 2021.08.17 |
정수 내림차순으로 배치하기 (0) | 2021.08.13 |
댓글