프로그래머스, 자바스크립트) 정수를 나선형으로 배치하기

2024. 6. 16. 17:26·개발/알고리즘(코딩테스트)

문제

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

 

프로그래머스

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

programmers.co.kr

풀이

우선, 0으로 채운 n x n 크기의 배열을 만들어 준다.

  // 결과를 저장할 이차원 배열을 n x n 크기로 만들기
  const result = Array.from({ length: n }, () => Array(n).fill(0));

 

나선형으로 변수를 채우기 위해 필요한 방향 변수를 정의 해놓는다.

  let num = 1;
  let row = 0, col = 0;
  let dr = 0, dc = 1; // 시작 방향: 오른쪽

다음에 for문을 사용하여 조건에 맞게 숫자를 채운다. for 문은 n x n 크기 만큼 반복된다.


  for (let i = 0; i < n * n; i++) {
    result[row][col] = num++;
    const nextRow = row + dr;
    const nextCol = col + dc;

    // 다음 위치가 범위를 벗어나거나 이미 채워진 경우 방향 전환
    if (nextRow < 0 || nextRow >= n || nextCol < 0 || nextCol >= n || result[nextRow][nextCol] !== 0) {
      [dr, dc] = [dc, -dr]; // 방향을 전환 (오른쪽 -> 아래 -> 왼쪽 -> 위)
    }

    row += dr;
    col += dc;
  }

 

전체 풀이는 다음과 같다.

function solution(n) {
  const result = Array.from({ length: n }, () => Array(n).fill(0));
  let num = 1;
  let row = 0, col = 0;
  let dr = 0, dc = 1; // 시작 방향: 오른쪽

  for (let i = 0; i < n * n; i++) {
    result[row][col] = num++;
    const nextRow = row + dr;
    const nextCol = col + dc;

    // 다음 위치가 범위를 벗어나거나 이미 채워진 경우 방향 전환
    if (nextRow < 0 || nextRow >= n || nextCol < 0 || nextCol >= n || result[nextRow][nextCol] !== 0) {
      [dr, dc] = [dc, -dr]; // 방향을 전환 (오른쪽 -> 아래 -> 왼쪽 -> 위)
    }

    row += dr;
    col += dc;
  }

  return result;
}

// 예시 실행
console.log(solution(4)); // [[1, 2, 3, 4], [12, 13, 14, 5], [11, 16, 15, 6], [10, 9, 8, 7]]
console.log(solution(5)); // [[1, 2, 3, 4, 5], [16, 17, 18, 19, 6], [15, 24, 25, 20, 7], [14, 23, 22, 21, 8], [13, 12, 11, 10, 9]]

 

저작자표시 비영리 변경금지

'개발 > 알고리즘(코딩테스트)' 카테고리의 다른 글

프로그래머스, 자바스크립트) 내적  (0) 2024.06.29
프로그래머스, 자바스크립트) 수박수박수박수박수박수?  (0) 2024.06.22
프로그래머스, 자바스크립트) 안전지대  (0) 2024.06.09
프로그래머스, 자바스크립트) 주사위 게임 3  (0) 2024.06.07
프로그래머스, 자바스크립트) 분수의 덧셈  (0) 2024.06.06
'개발/알고리즘(코딩테스트)' 카테고리의 다른 글
  • 프로그래머스, 자바스크립트) 내적
  • 프로그래머스, 자바스크립트) 수박수박수박수박수박수?
  • 프로그래머스, 자바스크립트) 안전지대
  • 프로그래머스, 자바스크립트) 주사위 게임 3
빔네모
빔네모
console.log("빔네모")
  • 빔네모
    bimnemo("개발")
    빔네모
  • 전체
    오늘
    어제
    • 기록 (140) N
      • 기술 (33) N
        • JavaScript (1)
        • TypeScript (9)
        • React.js (10) N
        • Next.js (0)
        • 라이브러리,도구 (3)
        • HTML,CSS (1) N
        • CS (5)
        • BE (4)
      • 개발 (95)
        • 프로젝트 (0)
        • 트러블슈팅 (5)
        • 알고리즘(코딩테스트) (90)
      • 정보 (4)
      • 취미 (8)
        • 감상 (8)
  • 인기 글

  • 최근 댓글

  • 최근 글

  • hELLO· Designed By정상우.v4.10.3
빔네모
프로그래머스, 자바스크립트) 정수를 나선형으로 배치하기
상단으로

티스토리툴바