암호 해독

nacSeo (낙서)·2024년 5월 13일
0

프로그래머스

목록 보기
163/169

문제 설명

군 전략가 머쓱이는 전쟁 중 적군이 다음과 같은 암호 체계를 사용한다는 것을 알아냈습니다.

암호화된 문자열 cipher를 주고받습니다.
그 문자열에서 code의 배수 번째 글자만 진짜 암호입니다.
문자열 cipher와 정수 code가 매개변수로 주어질 때 해독된 암호 문자열을 return하도록 solution 함수를 완성해주세요.

제한사항

1 ≤ cipher의 길이 ≤ 1,000
1 ≤ code ≤ cipher의 길이
cipher는 소문자와 공백으로만 구성되어 있습니다.
공백도 하나의 문자로 취급합니다.

나의 코드

  • 첫 번째 코드
class Solution {
    public String solution(String cipher, int code) {
        String answer = "";
        for(int i=1; i<cipher.length(); i++) {
            if(i%code==0) answer += cipher.charAt(i-1);
        }
        return answer;
    }
}

배수 번째 글자를 뽑아낼 때 인덱스와 1이 차이나므로 cipher.charAt(i-1)로 뒀는데, 마지막 배수 번째 글자가 빠짐

  • 두 번째 코드
class Solution {
    public String solution(String cipher, int code) {
        String answer = "";
        for(int i=1; i<cipher.length(); i++) {
            if(i%code==code-1) answer += cipher.charAt(i);
        }
        return answer;
    }
}


따라서, 결과쪽이 아닌 조건문 조건쪽에서 i%code==code-1로 바꿔줬음. 코드 실행에서는 통과되었으나, 제출 후 채점하기에서 테스트 3개가 실패..

  • 최종 코드
class Solution {
    public String solution(String cipher, int code) {
        String answer = "";
        for(int i=code-1; i<cipher.length(); i+=code) {
            answer += cipher.charAt(i);
        }
        return answer;
    }
}

단순히 반복문 조건을 만족시켜 해결..! 😅

다른 사람 코드

class Solution {
    public String solution(String cipher, int code) {
        String answer = "";

        for (int i = code; i <= cipher.length(); i = i + code) {
            answer += cipher.substring(i - 1, i);
        }

        return answer;
    }
}

substring() 메서드 활용

느낀 점

한 가지 방법에 꽂혀 수정하다가 시간 소요가 좀 있었다 😅 막힐 때 좀 더 크게 보면서 다른 방법을 찾아내는 마인드를 가져야겠다.

profile
백엔드 개발자 김창하입니다 🙇‍♂️

0개의 댓글