코딩테스트/프로그래머스

[프로그래머스] 코드 처리하기 자바 java

플래시🦥 2023. 8. 10.
반응형

https://school.programmers.co.kr/learn/courses/30/lessons/181932#

 

프로그래머스

코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.

programmers.co.kr

문제 설명
문자열 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 합니다.

제한사항
1 ≤ code의 길이 ≤ 100,000
code는 알파벳 소문자 또는 "1"로 이루어진 문자열입니다.

 


문자열 중 "1"을 만났을 경우 mode가 true이면 짝수번째 문자를, false이면 홀수번째 문자를 append 하도록 구현하였다. 

1을 만났을 경우 mode =! mode 하여 반댓값을 가지도록 해주었다. 

for문이 끝난 후 만들어진 결과값이 없다면 (입력값이 "1" 이거나 비어있을 경우) EMPTY를 출력할 수 있도록 하였다. (구현 안 하면 테스트 케이스 12,13번 통과 못함. )

 

전체코드

class Solution {
    public String solution(String code) {
        StringBuilder sb = new StringBuilder();
        boolean mode =false;
        
        for(int i=0;i<code.length();i++){
            if(code.charAt(i)=='1'){
                mode=!mode;
                continue;
            } 
            
            if(!mode&&i%2==0){
                sb.append(code.charAt(i));
            }else if(mode&& i%2==1){
                sb.append(code.charAt(i));
            }
        }
        
        if(sb.toString().isBlank())  sb.append("EMPTY");
        
        return sb.toString();
    }
}
728x90
반응형

댓글