문제 확인

 

프로그래머스

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

programmers.co.kr

 

나의 풀이

재귀적으로 반복 됨!

재귀를 활용한 풀이 : 코드 작성 실패
  • n 이 3 보다 클 경우, 전체 삼각형은 외부 삼각형, 내부 삼각형으로 분리할 수 있다는 점을 주목해 풀이를 시도했다.
  • 코드 작성엔 실패했고, 다른 사람이 작성한 아래 코드를 보고 이해한 뒤 주석을 작성했다.
arr = []


def draw(x, y, cnt, num):
    if cnt < 1:
        return
    number = num
    # 삼각형의 좌측 대각선
    for i in range(cnt):
        arr[x + i][y] = number
        number += 1
    # 삼각형의 밑변
    for i in range(1, cnt):
        arr[x + cnt - 1][y + i] = number
        number += 1
    # 삼각형의 우측 대각선
    for i in range(1, cnt - 1):
        arr[x + cnt - 1 - i][y + cnt - 1 - i] = number
        number += 1
    # 삼각형의 새로운 시작 점
    # 시작점 x : 1 -> 3 -> 5 -> ...
    # 시작점 y : 1 -> 2 -> 3 -> ...
    draw(x + 2, y + 1, cnt - 3, number)


def solution(n):
    global arr
    arr = [[0] * n for _ in range(n)]
    draw(0, 0, n, 1)

    answer = []
    for i in range(n):
        for j in range(i + 1):
            answer.append(arr[i][j])
    return answer

 

다른 방법을 사용한 풀이

  • 삼각형의 연속된 부분을 쭉 이어서 채운다고 생각할 수도 있다.
  • 이 경우, 매번 $N$, $N - 1$, $N - 2$...의 횟수로, '왼쪽 대각선 - 밑변 - 오른쪽 대각선'을 채운다고 보면 된다.
# 3 번의 실행 마다, 채워지는 위치가 달라짐 | 왼쪽 대각선 -> 밑변 -> 오른쪽 대각선
# 매번 채우는 개수가 달라짐 | n -> n - 1 -> n - 2 ...

def solution(n):
    tri_info = [[0 for _ in range(n)] for _ in range(n)]
    # 채워 넣을 숫자
    num = 1
    # 채워 넣을 위치
    x, y = -1, 0
    # 한 줄 단위로 채우기
    for i in range(n):
        # 채울 수의 개수
        for _ in range(i, n):
            # 왼쪽 대각선을 채울 경우
            if i % 3 == 0:
                x += 1
            # 밑변을 채울 경우
            elif i % 3 == 1:
                y += 1
            # 오른쪽 대각선을 채울 경우
            else:
                x -= 1
                y -= 1
            # 채우기
            tri_info[x][y] = num
            num += 1
    # 1개의 행으로 변경하기
    answer = []
    for row in tri_info:
        answer.extend(sum([], [e for e in row if e != 0]))
    return answer