[programmers/py] n^2 배열 자르기

승민·2023년 10월 20일

알고리즘

목록 보기
34/171
post-thumbnail

n^2 배열 자르기

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

문제 설명

정수 n, left, right가 매개변수로 주어집니다. 주어진 과정대로 만들어진 1차원 배열을 return 하도록 solution 함수를 완성해주세요.

다음 과정을 거쳐서 1차원 배열을 만들고자 합니다.

  1. n행 n열 크기의 비어있는 2차원 배열을 만듭니다.
  2. i = 1, 2, 3, ..., n에 대해서, 다음 과정을 반복합니다.
  3. 1행 1열부터 i행 i열까지의 영역 내의 모든 빈 칸을 숫자 i로 채웁니다.
    4.1행, 2행, ..., n행을 잘라내어 모두 이어붙인 새로운 1차원 배열을 만듭니다.
  4. 새로운 1차원 배열을 arr이라 할 때, arr[left], arr[left+1], ..., arr[right]만 남기고 나머지는 지웁니다.

제한 사항

1 ≤ n ≤ 10^7
0 ≤ left ≤ right < n^2
right - left < 10^5

  • n**2으로 풀 수 없다.

풀이 설명

각 index의 몫과 나머지 중 큰 값+1이 배열[index]의 값이다.

n = 3
index = 0 1 2, 3 4 5, 6 7 8
i//n = 0 0 0, 1 1 1, 2 2 2
i%n = 0 1 2, 0 1 2, 0 1 2
value = 1 2 3, 2 2 3, 3 3 3
return = 3 2 2 3
def solution(n, left, right):
    arr = []
    for i in range(left, right+1):
        num = max(i//n, i%n)
        arr.append(num+1)
    
    return arr

0개의 댓글