반응형
💁♀️ 링크
programmers.co.kr/learn/courses/30/lessons/12930
📃 문제
문자열 s는 한 개 이상의 단어로 구성되어 있습니다. 각 단어는 하나 이상의 공백문자로 구분되어 있습니다. 각 단어의 짝수번째 알파벳은 대문자로, 홀수번째 알파벳은 소문자로 바꾼 문자열을 리턴하는 함수, solution을 완성하세요.
제한 사항
- 문자열 전체의 짝/홀수 인덱스가 아니라, 단어(공백을 기준)별로 짝/홀수 인덱스를 판단해야합니다.
- 첫 번째 글자는 0번째 인덱스로 보아 짝수번째 알파벳으로 처리해야 합니다.
입출력 예
s | return |
try hello world | TrY HeLlO WoRlD |
🐾 문제풀이
1. StringTokenizer을 사용해 공백을 기준으로 문자열을 자른다.
(3번째 인자값을 true로 두어, 공백문자까지 토큰으로 포함)
2. 순차적으로 토큰을 가져온다
- split("")을 이용해서 배열로 만들고, 배열의 인덱스가 홀수인 경우만 소문자로 변경해준다.
- 배열을 문자열로 변환하여 answer에 더해준다.
* StringTokenizer 사용법은 아래의 포스팅에 더 자세하게 나와있습니다.
[JAVA] StringTokenizer 사용법
📚 생성자(Constructor) public StringTokenizer(String str); public StringTokenizer(String str, String delim); public StringTokenizer(String str, String delim, boolean returnDelims); Parameters str ..
jeleedev.tistory.com
💻 코드
import java.util.StringTokenizer;
class Solution {
public String solution(String s) {
String answer = "";
// 공백을 기준으로 문자열을 나눈다.
StringTokenizer words = new StringTokenizer(s.toUpperCase(), " ", true);
// 순차적으로 토큰을 가져와 토큰의 홀수번째 문자를 소문자로 변경하고, answer문자열에 더해준다.
while(words.hasMoreTokens()){
String[] word = words.nextToken().split("");
for(int j=1; j<word.length; j+=2){
word[j] = word[j].toLowerCase();
}
answer += String.join(",", word);
}
return answer.replace(",", "");
}
}
반응형
'프로그래밍 > 알고리즘' 카테고리의 다른 글
[프로그래머스] [Level1] 자연수 뒤집어 배열로 만들기 - Java (0) | 2021.01.06 |
---|---|
[프로그래머스] [Level1] 자릿수 더하기 - Java (0) | 2021.01.06 |
[프로그래머스] [Level] 약수의 합 - Java (0) | 2021.01.05 |
[프로그래머스] [Level1] 내적 - Java (0) | 2021.01.05 |
[프로그래머스] [Level1] 소수찾기 - Java (0) | 2021.01.04 |