❇️오늘의 학습 키워드 : 소용돌이 예쁘게 출력하기(백준 #1022)
문제
크기가 무한인 정사각형 모눈종이가 있다. 모눈종이의 각 정사각형은 행과 열의 쌍으로 표현할 수 있다.
이 모눈종이 전체를 양의 정수의 소용돌이 모양으로 채울 것이다. 일단 숫자 1을 0행 0열에 쓴다. 그리고 나서 0행 1열에 숫자 2를 쓴다. 거기서 부터 소용돌이는 반시계 방향으로 시작된다. 다음 숫자는 다음과 같이 채우면 된다.
-3 -2 -1 0 1 2 3
--------------------
-3 |37 36 35 34 33 32 31
-2 |38 17 16 15 14 13 30
-1 |39 18 5 4 3 12 29
0 |40 19 6 1 2 11 28
1 |41 20 7 8 9 10 27
2 |42 21 22 23 24 25 26
3 |43 44 45 46 47 48 49
이 문제는 위와 같이 채운 것을 예쁘게 출력하면 된다. r1, c1, r2, c2가 입력으로 주어진다. r1, c1은 가장 왼쪽 위 칸이고, r2, c2는 가장 오른쪽 아래 칸이다.
예쁘게 출력한다는 것은 다음과 같이 출력하는 것이다.
- 출력은 r1행부터 r2행까지 차례대로 출력한다.
- 각 원소는 공백으로 구분한다.
- 모든 행은 같은 길이를 가져야 한다.
- 공백의 길이는 최소로 해야 한다.
- 모든 숫자의 길이(앞에 붙는 공백을 포함)는 같아야 한다.
- 만약 수의 길이가 가장 길이가 긴 수보다 작다면, 왼쪽에서부터 공백을 삽입해 길이를 맞춘다.
입력
첫째 줄에 네 정수 r1, c1, r2, c2가 주어진다.
출력
r2 - r1 + 1개의 줄에 소용돌이를 예쁘게 출력한다.
제한
- -5 000 ≤ r1, c1, r2, c2 ≤ 5,000
- 0 ≤ r2 - r1 ≤ 49
- 0 ≤ c2 - c1 ≤ 4
예제 입력 1
-3 -3 2 0
예제 출력 1
37 36 35 34
38 17 16 15
39 18 5 4
40 19 6 1
41 20 7 8
42 21 22 23
예제 입력 2
-2 2 0 3
예제 출력 2
13 30
12 29
11 28
예제 입력 3
-1 -2 -1 1
예제 출력 3
18 5 4 3
예제 입력 4
0 0 0 0
예제 출력 4
1
정답 코드
r1, c1, r2, c2 = map(int, input().split())
rows, cols = r2 - r1 + 1, c2 - c1 + 1
grid = [[0] * cols for _ in range(rows)]
max_val = 0
def calculate_value(row, col):
layer = max(abs(row), abs(col))
start = (2 * layer - 1) ** 2 + 1
if row == layer:
return start + 7 * layer + col - 1
elif col == -layer:
return start + 5 * layer + row - 1
elif row == -layer:
return start + 3 * layer - col - 1
else:
return start + layer - row - 1
for i in range(rows):
for j in range(cols):
grid[i][j] = calculate_value(r1 + i, c1 + j)
max_val = max(max_val, grid[i][j])
max_width = len(str(max_val))
for row in grid:
print(" ".join(str(val).rjust(max_width) for val in row))
❇️오늘의 회고
- 집중이 너무 안되는 날이었어서 많이 고민하지 못하고 블로그 정답코드를 확인했다...
- 여러번 다시 풀어보면서 남에게 설명할 수 있을 정도로 만들어야겠다!
- 내일 11시, 문제를 풀기 전에 위 문제를 한번 더 복습하고 내일 문제에 사용된 알고리즘에 대해서 공부할 것이다!🙂
'99클럽 코테 스터디' 카테고리의 다른 글
99클럽 코테 스터디 21일차 TIL - 우주 탐사선(백준 #17182) (2) | 2024.11.17 |
---|---|
99클럽 코테 스터디 20일차 TIL - 소트(백준 #1083) (0) | 2024.11.16 |
99클럽 코테 스터디 18일차 TIL - 센서(백준 #2212) (0) | 2024.11.14 |
99클럽 코테 스터디 17일차 TIL - 작업(백준 #2056) (2) | 2024.11.13 |
99클럽 코테 스터디 16일차 TIL - 비슷한 단어(백준 #2179) (4) | 2024.11.12 |