티스토리 뷰
https://programmers.co.kr/learn/courses/30/lessons/68645
문제 설명
정수 n이 매개변수로 주어집니다. 다음 그림과 같이 밑변의 길이와 높이가 n인 삼각형에서 맨 위 꼭짓점부터 반시계 방향으로 달팽이 채우기를 진행한 후, 첫 행부터 마지막 행까지 모두 순서대로 합친 새로운 배열을 return 하도록 solution 함수를 완성해주세요.
제한사항
- n은 1 이상 1,000 이하입니다.
입출력 예
문제 풀이
삼각형을 볼 때 회전하는 방향은 항상 정해져있다.
아래로 내려가는 방향 -> 오른쪽으로 가는 방향 -> 위로 올라가는 방향 -> 아래로 내려가는 방향....
위 순서로 반복해서 진행된다.
n이 증가할 때 마다 삼각형이 회전하는 곳의 숫자를 살펴보면
n = 2 -> 2
n = 3 -> 3, 5
n = 4 -> 4, 7, 9
n = 5 -> 5, 9, 12, 14
n = 6 -> 6, 11, 15, 18, 20
첫 번째로 회전하는 지점은 숫자가 n인 경우에 회전한다.
이후에는 n-1 만큼 증가한 숫자에서 회전을 하고 그 이후 회전해야하는 숫자를 만난 경우는 n-2 만큼 증가한 숫자에서 회전해야 한다. 위와 같이 반복하면서 증가하다가 n이 1인경우 마지막 숫자를 적게 된다.
def solution(n):
answer = []
snail_row = [[0 for j in range(1, i+1)] for i in range(1, n+1)]
cnt = 0
for i in range(1,n+1):
cnt += i
x, y = 0, 0
flag = 0
next_dir = n-1
for num in range(1,cnt+1):
snail_row[x][y] = num
if flag == 0: # 왼쪽 아래로 진행
x += 1
if num == next_dir: # 방향을 바꿔야되는 경우
flag = 1
n -= 1
next_dir = next_dir + n
elif flag == 1: # 오른쪽으로 진행
y += 1
if num == next_dir:
flag = 2
n -= 1
next_dir = next_dir + n
elif flag == 2: # 왼쪽 상단으로 진행
x -= 1
y -= 1
if num == next_dir:
flag = 0
n -= 1
next_dir = next_dir + n
else:
continue
for row in snail_row:
for data in row:
answer.append(data)
return answer
print(solution(5))
# n = 2 -> 2
# n = 3 -> 3, 5
# n = 4 -> 4, 7, 9
# n = 5 -> 5, 9, 12, 14
# n = 6 -> 6, 11, 15, 18, 20
'알고리즘' 카테고리의 다른 글
[프로그래머스] n^2 배열 자르기 - 파이썬 (0) | 2022.02.17 |
---|---|
[프로그래머스] 영어 끝말잇기 - 파이썬 (0) | 2022.02.09 |
[프로그래머스] 2개 이하로 다른 비트 - 파이썬 (0) | 2022.02.08 |
[프로그래머스] 괄호 회전하기 - 파이썬 (0) | 2022.01.26 |
[프로그래머스] 오픈채팅방 - 파이썬 (0) | 2022.01.25 |
댓글
공지사항
최근에 올라온 글
최근에 달린 댓글
- Total
- Today
- Yesterday
링크
TAG
- 8주차 회고
- dm-zoned 코드분석
- 알림개선기
- 스프링 Logback
- 3차 데모데이
- 스프링 프레임워크
- CI/CD
- Spring
- 회고
- 네트워크
- 5주차 회고
- java
- 프로젝트
- 알림기능개선기
- 환경 별 로깅 전략 분리
- 파이썬
- 피움 6주차 회고
- 백준
- 런칭 페스티벌
- 피움
- 팀프로젝트
- 2차 데모데이
- ZNS SSD
- ZNS
- jpa
- 스프링 부트
- dm-zoned
- 우테코
- 스프링MVC
- 우테코 회고
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | 5 | 6 | 7 |
8 | 9 | 10 | 11 | 12 | 13 | 14 |
15 | 16 | 17 | 18 | 19 | 20 | 21 |
22 | 23 | 24 | 25 | 26 | 27 | 28 |
29 | 30 | 31 |
글 보관함