본문 바로가기
코딩테스트 연습

코드 처리하기

by 신재은👩🏼‍💻 2024. 4. 13.

문제 설명

문자열 code가 주어집니다.
code를 앞에서부터 읽으면서 만약 문자가 "1"이면 mode를 바꿉니다. mode에 따라 code를 읽어가면서 문자열 ret을 만들어냅니다.

mode는 0과 1이 있으며, idx를 0 부터 code의 길이 - 1 까지 1씩 키워나가면서 code[idx]의 값에 따라 다음과 같이 행동합니다.

  • mode가 0일 때
  • mode가 1일 때

문자열 code를 통해 만들어진 문자열 ret를 return 하는 solution 함수를 완성해 주세요.

단, 시작할 때 mode는 0이며, return 하려는 ret가 만약 빈 문자열이라면 대신 "EMPTY"를 return 합니다.

 

제한사항

  • 1 ≤ code의 길이 ≤ 100,000

 

입출력 예

code result
"abc1abc1abc" "acbac"

class Solution {
    public String solution(String code) {
    
        String answer = "";
        StringBuilder ret = new StringBuilder();
        int mode = 0;
        
        for(int i=0; i<code.length(); i++) {
            char c = code.charAt(i);
            if(c == '1') {
                mode = 1 - mode;
            } else {
                if(mode == 0 && i % 2 == 0) {
                    ret.append(c);
                } else if(mode == 1 && i % 2 != 0) {
                    ret.append(c);
                }
            }
        }
        
        answer = ret.toString();
        
        return answer.length() == 0 ? "EMPTY" : answer;
    }
}


기억할 것

 

  • answer == ""는 참조 비교를 수행하므로, 문자열의 내용 비교에는 적합하지 않습니다.
  • answer.equals("")는 문자열의 내용이 빈 문자열과 정확히 일치하는지를 확인합니다.
  • answer.length() == 0은 문자열의 길이가 0인지를 확인하여, 간접적으로 문자열이 비어 있는지 검사합니다. 이 방법은 가장 효율적인 방법으로 널리 사용됩니다.

문자열의 내용을 비교할 때는 .equals() 메서드를 사용하고, 문자열이 비어 있는지만을 확인할 때는 .length() == 0을 사용하는 것이 좋다.


class Solution {

    public String solution(String code) {

        StringBuilder answer = new StringBuilder();

        int mode = 0;

        for (int i = 0; i < code.length(); i++) {

            char current = code.charAt(i);

            if (current == '1') {

                mode = mode == 0 ? 1 : 0;

                continue;

            }

 

            if (i % 2 == mode) {

                answer.append(current);

            }

        }

        return answer.length() == 0 ? "EMPTY" : answer.toString();

    }

}

 

좋은 예시...

'코딩테스트 연습' 카테고리의 다른 글

약수 구하기  (0) 2024.04.13
가장 큰 수 찾기  (0) 2024.04.13
9로 나눈 나머지  (0) 2024.04.13
접미사 배열  (0) 2024.04.12
가까운 1 찾기  (0) 2024.04.12