🗝️ Algorithm/🟩 백준
🟩 [백준] [Python] [Gold3] 14890번_경사로
Dbswnstjd
2023. 6. 19. 11:38
문제
https://www.acmicpc.net/problem/14890
14890번: 경사로
첫째 줄에 N (2 ≤ N ≤ 100)과 L (1 ≤ L ≤ N)이 주어진다. 둘째 줄부터 N개의 줄에 지도가 주어진다. 각 칸의 높이는 10보다 작거나 같은 자연수이다.
www.acmicpc.net
풀이
# 백준 14890번 문제 - 경사로
n, l = map(int, input().split())
graph = [list(map(int, input().split())) for _ in range(n)]
ans = 0
def check_line(line):
for i in range(1, n):
if abs(line[i] - line[i - 1]) > 1:
return False
if line[i] < line[i - 1]:
for j in range(l):
if i + j >= n or line[i] != line[i + j] or slope[i + j]:
return False
if line[i] == line[i + j]:
slope[i + j] = True
elif line[i] > line[i - 1]:
for j in range(l):
if i - j - 1 < 0 or line[i - 1] != line[i - j - 1] or slope[i - j - 1]:
return False
if line[i - 1] == line[i - j - 1]:
slope[i - j - 1] = True
return True
for i in range(n):
slope = [False] * n
if check_line([graph[i][j] for j in range(n)]):
ans += 1
for j in range(n):
slope = [False] * n
if check_line([graph[i][j] for i in range(n)]):
ans += 1
print(ans)