본문 바로가기
코테 준비(with 프로그래머스)

프로그래머스 day5 - 코드 처리하기

by jeong11 2023. 11. 7.
반응형
문제 설명

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

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

  • mode가 0일 때
    code[idx]가 "1"이 아니면 idx가 짝수일 때만 ret의 맨 뒤에 code[idx]를 추가합니다.
    code[idx] "1"이면 mode 0에서 1 바꿉니다.

  • mode가 1일 때
    code[idx]가 "1"이 아니면 idx가 홀수일 때만 ret의 맨 뒤에 code[idx]를 추가합니다.
    code[idx] "1"이면 mode 1에서 0으로 바꿉니다.

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

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

입출력 예
code result
"abc1abc1abc" "acbac"

입출력 예 #1
code의 각 인덱스 i에 따라 다음과 같이 mode와 ret이 변합니다. 

i code[i] mode ret
0 "a" 0 "a"
1 "b" 0 "a"
2 "c" 0 "ac"
3 "1" 1 "ac"
4 "a" 1 "ac"
5 "b" 1 "acb"
6 "c" 1 "acb"
7 "1" 0 "acb"
8 "a" 0 "acba"
9 "b" 0 "acba"
10 "c" 0 "acbac"
"acbca"를 return합니다 (2023/05/18 지문 수정)

 

 

이런 문제 너무  조건이 많아서 문제를 읽다가 아찔해진다... 

for문이랑 if문 쓰면서 디버그 해보면서 풀 수 밖에 없었다 

 

*내가 해결한 코드*

 

문제 정리

=> 1) code[idx] =1 이면 기존의 mode는 변경된다 

=> 2) code[idx]가 1이 아니면 짝수인 경우/홀수인 경우 문자열 뒤에 code[idx]를 추가한다

=> 3) 빈 문자열이 만들어질 경우 "EMPTY"를 return한다

 

class Solution {
    public String solution(String code) {
        String answer = "";
        int mode = 0;
        for(int i = 0; i<code.length(); i++){
           
            // 1)change mode
            if(code.charAt(i) == '1' && mode == 0){
                mode = 1;
            }else if(code.charAt(i) == '1' && mode == 1){
                mode = 0;
            }
            
            // 2)add code[idx]
            if(mode == 0){
                if(code.charAt(i) != '1' && i % 2 == 0){
                    answer += code.charAt(i);
                }
            }else if(mode == 1){
                if(code.charAt(i) != '1' && i % 2 != 0){
                    answer += code.charAt(i);
                }
            }
                
        }
        // 3)test12,13 fail
        if(answer.isEmpty()){
            return "EMPTY";
        }
        
        return answer;
    }
}

 

처음에는 mode change와 짝수/홀수인 경우 code[idx]를 추가해주는 조건을 &&으로 표현하려고 했으나 코드가 너무 복잡해지고 원하는 답이 나오지 않아 각각 나누었다

1), 2)번에만 집중하느라 3)번을 처음에 놓쳤는데 이 경우 코드 실행은 맞게 나오지만 제출 후 채점하기 에서 fail이 나온다 

return "EMPTY"해주니 성공! 

반응형