Python/Coding Test

[Coding Test] [1차] 비밀지도

gangee 2023. 5. 26. 22:13

목차

    728x90
    반응형

    [1차] 비밀지도(2018 KAKAO BLIND RECRUITMENT)

    문제 설명

    비밀지도
    네오는 평소 프로도가 비상금을 숨겨놓는 장소를 알려줄 비밀지도를 손에 넣었다. 그런데 이 비밀지도는 숫자로 암호화되어 있어 위치를 확인하기 위해서는 암호를 해독해야 한다. 다행히 지도 암호를 해독할 방법을 적어놓은 메모도 함께 발견했다.

    1. 지도는 한 변의 길이가 n인 정사각형 배열 형태로, 각 칸은 "공백"(" ") 또는 "벽"("#") 두 종류로 이루어져 있다.
    2. 전체 지도는 두 장의 지도를 겹쳐서 얻을 수 있다. 각각 "지도 1"과 "지도 2"라고 하자. 지도 1 또는 지도 2 중 어느 하나라도 벽인 부분은 전체 지도에서도 벽이다. 지도 1과 지도 2에서 모두 공백인 부분은 전체 지도에서도 공백이다.
    3. "지도 1"과 "지도 2"는 각각 정수 배열로 암호화되어 있다.
    4. 암호화된 배열은 지도의 각 가로줄에서 벽 부분을 1, 공백 부분을 0으로 부호화했을 때 얻어지는 이진수에 해당하는 값의 배열이다.

    예시

    문제 풀이

    -bin() : 정수를 이진수로 바꿔주는 함수 앞에 ob가 붙음
    -zfill() : 괄호안에 들어가는 수 보다 모자란 공간만큼 앞에 0을 붙여주는 함수 (비슷한 함수 rjust가 있음)

    • 처음 시도했던 풀이 방식
    1. arr1, arr2를 이진수로 변경한 값을 넣을 리스트 생성
    2. 반복문과 bin함수를 이용해 arr1, arr2를 이진수로 변경하고 n수 만큼을 0으로 채워줌
    3. 변경된 이진수를 각각 arr1_b, arr2_b 에 append 함
    4. 조건문을 통해 arr1_b, arr2_b를 OR연산자를 이용해 비교하여 1인경우 answer에 append 함
    5. 생성된 answer의 replace함수를 통해 1을 #으로 0을 공백으로 변경함
    • 성공한 풀이 방식
    1. 반복문의 범위를 n으로 설정하고 arr1과 arr2를 이진수로 바꾸고 OR연산자로 비교하여 n만큼을 0으로 채운 리스트를 a에 저장
    2. replace함수를 통해 a의 0을 공백으로 변경하고 b에 저장
    3. replace함수를 통해 b의 1을 #으로 변경하고 c에 저장
    4. c를 answer에 append

    정답 코드

    def solution(n, arr1, arr2):
        answer = []
    #     arr1_b = []
    #     arr2_b = []
    
    #     for i in arr1:
    #         num1_b = bin(i)[2:].zfill(n)
    #         arr1_b.append(num1_b) # arr1 이진수로 변경
    
    #     for i in arr2:
    #         num2_b = bin(i)[2:].zfill(n)
    #         arr2_b.append(num2_b) # arr2 이진수로 변경
    
    #     if arr1_b==1 | arr2_b==1:
    #         answer.append()
    
        for i in range(n):
            a = bin(arr1[i] | arr2[i])[2:].zfill(n)
            b = a.replace('0', ' ')
            c = b.replace('1', '#')
    
            answer.append(c)
        return answer
    * 이 문제는 프로그래머스 코딩테스트 연습 1단계 문제입니다.
    728x90
    반응형