Moon_Dev_Blog :)

[프로그래머스] 수박수박수박수박수박수? / Java 본문

IT/알고리즘풀이

[프로그래머스] 수박수박수박수박수박수? / Java

돌베기 2021. 2. 26. 11:50

    안녕하세요. 본 포스팅은 주관적으로 작성되며, 틀린 정보가 있을시에 따끔한 충고 부탁드리겠습니다. 감사합니다.

 

    내용 : 

문제 설명

길이가 n이고, 수박수박수박수....와 같은 패턴을 유지하는 문자열을 리턴하는 함수, solution을 완성하세요. 예를들어 n이 4이면 수박수박을 리턴하고 3이라면 수박수를 리턴하면 됩니다.

제한 조건

  • n은 길이 10,000이하인 자연수입니다.

 

문제 풀이

class Solution {
    public String solution(int n) {
        String answer = "";
        String word = "수박";
        
        if(n <= 10000) {
            for(int i=0; i < n; i++) {            
                answer += word;
            }                
            if(n % 2 == 1) {                
                answer = answer.substring(0, n);
            } else if(n % 2 == 0) {
                int dev = answer.length() / 2;
                answer = answer.substring(0, dev);                
            }
        }
        
                    
        return answer;
    }
    

}

10000개 이하일때 n의 비즈니스 로직을 태우며, 수박이라는 단어를 n의 길이만큼 더한 후 홀or짝 수의 로직에 따라 글자를 자르는 로직을 구성했다.

문제를 풀고보니 로직이 너무 복잡해 보였고, 리펙토링 과정에서 삼항연산자를 활용하여 코드를 간소화 시킬 수 있었다.

class Solution {
    public String solution(int n) {
        String answer = "";        
        
        if(n <= 10000) {
            for(int i=0; i < n; i++) {                            
                 answer += (i % 2 == 0) ? "수" : "박";
            }                            
        }
                        
        return answer;
    }    

}

 

 

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

Comments