[프로그래머스/java]이상한 문자 만들기

리트리버J

·

2020. 12. 30. 14:50

728x90

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

 

<나의 풀이>

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
class Solution {
    public String solution(String s) {
        
        StringBuilder sb = new StringBuilder();
        
        int index = 0;
        
        for(int i=0; i<s.length(); i++){
            if(s.charAt(i) == ' '){
                sb.append(' ');
                index = 0;
            }else{
                if(index % 2 == 0){
                    sb.append(Character.toUpperCase(s.charAt(i)));
                    index++;
                }else{
                    sb.append(Character.toLowerCase(s.charAt(i)));
                    index++;
                }
            }
        }
        return sb.toString();
    }
}
cs

<사이트 풀이>

*포인트*

1. String.split("")을 사용하여 String → String[]

2. 3항연산자 사용

3. 공백일 시 0, 공백이 아닐 시 1증가

4. 1이면 (홀수) → 대문자 / 2이면 (짝수) → 소문자

1
2
3
4
5
6
7
8
9
10
11
12
13
14
class Solution {
  public String solution(String s) {
 
        String answer = "";
        int cnt = 0;
        String[] array = s.split("");
 
        for(String ss : array) {
            cnt = ss.contains(" ") ? 0 : cnt + 1;
            answer += cnt%2 == 0 ? ss.toLowerCase() : ss.toUpperCase(); 
        }
      return answer;
  }
}
cs

출처: 프로그래머스 코딩 테스트 연습, https://programmers.co.kr/learn/challenges

728x90