Tesseractjh
한 걸음씩
Tesseractjh
전체 방문자
오늘
어제
  • 전체 (293)
    • IT (30)
      • JavaScript (7)
      • TypeScript (5)
      • React (5)
      • Next.js (3)
      • MongoDB (2)
      • Webpack (2)
      • HTML & CSS (1)
      • Git (0)
      • AWS (1)
      • 기타 (4)
    • 연습장 (259)
      • 백준(BOJ) 문제풀이 (185)
      • 프로그래머스 문제풀이 (61)
      • LeetCode 문제풀이 (2)
      • HackerRank 문제풀이 (7)
      • 낙서장 (3)
      • 기타 (1)
    • 프로젝트 (3)
      • 지뢰피하기 (1)
      • 키릴-라틴 문자 변환기 (1)
      • Flex & Grid (1)
    • 멋쟁이사자처럼 프론트엔드 스쿨 1기 (1)
      • 일기 & 회고록 (1)

인기 글

티스토리

hELLO · Designed By 정상우.
Tesseractjh

한 걸음씩

연습장/프로그래머스 문제풀이

[프로그래머스 Level 1] [1차] 비밀지도 - JavaScript

2022. 5. 6. 00:31

문제 링크

https://programmers.co.kr/learn/courses/30/lessons/17681

 

코딩테스트 연습 - [1차] 비밀지도

비밀지도 네오는 평소 프로도가 비상금을 숨겨놓는 장소를 알려줄 비밀지도를 손에 넣었다. 그런데 이 비밀지도는 숫자로 암호화되어 있어 위치를 확인하기 위해서는 암호를 해독해야 한다. 다

programmers.co.kr

풀이

function solution(n, arr1, arr2) {
    return [...Array(n)].map((_, i) => 
        [...(arr1[i] | arr2[i])
            .toString(2)
            .padStart(n, ' ')]
            .map(v => +v ? '#' : ' ')
            .join('')
    );
}

비트마스킹을 이용하여 겹쳐진 두 지도를 논리합 연산(|)으로 구하고,

이렇게 구한 지도를 2진수 문자열로 변경하여 0은 빈 문자열, 1은 #으로 바꿔서 해결하였다.

10진수 수를 2진수 문자열로 변환할 때, 자리수에 상관없이 앞에 0은 모두 생략이 되므로,

String.prototype.padStart를 활용하여 0이 생략되어 빈 부분을 빈 문자열로 메꾸었다.

저작자표시 비영리 (새창열림)

'연습장 > 프로그래머스 문제풀이' 카테고리의 다른 글

[프로그래머스 Level 2] 거리두기 확인하기 - JavaScript  (0) 2022.05.09
[프로그래머스 Level 2] 게임 맵 최단거리 - JavaScript  (0) 2022.05.09
[프로그래머스 Level 1] 신규 아이디 추천 - JavaScript  (0) 2022.04.23
[프로그래머스 Level 3] 다단계 칫솔 판매 - JavaScript  (0) 2022.04.11
[프로그래머스 Level 1] 완주하지 못한 선수 - JavaScript  (0) 2022.04.06
    '연습장/프로그래머스 문제풀이' 카테고리의 다른 글
    • [프로그래머스 Level 2] 거리두기 확인하기 - JavaScript
    • [프로그래머스 Level 2] 게임 맵 최단거리 - JavaScript
    • [프로그래머스 Level 1] 신규 아이디 추천 - JavaScript
    • [프로그래머스 Level 3] 다단계 칫솔 판매 - JavaScript
    Tesseractjh
    Tesseractjh
    바닐라 자바스크립트를 좋아하는 개발자입니다

    티스토리툴바