일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
Tags
- ubuntu
- 자바
- 그리디
- MySQL
- 백준 2512번
- 백준 16918번
- javascript
- 백준 18310번
- 모각코
- 머신러닝과 딥러닝
- 깃헙
- 백준 1253번
- react
- 다이나믹 프로그래밍
- AWS
- SWEA 15612번
- 백준 15787번
- 백준 17451번
- 백준 1987
- 백준 1331번
- 백준 3085번
- 알고리즘
- HUFS 모각코 캠프
- SQL
- 백준
- 다이나믹프로그래밍
- 그래프
- Python
- 명품자바
- java_programming
Archives
- Today
- Total
차곡차곡
[SWEA/Python] SW Expert Academy 1206번 - View 본문
SW Expert Academy #1206 View
def calc(i):
length = 255
for dx in [-2, -1, 1, 2]:
x = i + dx
if 0 <= x < num:
if building[i] > building[x]:
length = min(length, building[i] - building[x])
else:
return False
return length
for k in range(10):
num = int(input())
building = list(map(int, input().split()))
cnt = 0
for i in range(2, num-2):
rest = calc(i)
if rest:
cnt += rest
print(f'#{k+1} {cnt}')
- 건물 순서대로 현재 구하고 있는 건물의 양쪽 2 이하의 거리에 현재 건물보다 높은 건물이 있는지 확인한다.
- 높은 건물이 있을 경우 조망권이 확보되지 않는 건물로 바로 False를 리턴해준다.
- 높은 건물이 없을 경우 [ 현재 건물 길이 - 양쪽 2 이하의 거리에 있는 건물 중 가장 높은 건물 길이 ] 값을 리턴해준다. 해당 값이 현재 건물에서 조망권이 확보되는 세대 수이다.
- 리턴된 세대 수들을 합해준다.
'CS > Algorithm' 카테고리의 다른 글
[BOJ/Python] 백준 23971번 - ZOAC 4 (2) | 2023.02.16 |
---|---|
[SWEA/Python] SW Expert Academy 5215번 - 햄버거 다이어트 (0) | 2022.11.20 |
[SWEA/Python] SW Expert Academy 14692번 - 통나무 자르기 (0) | 2022.11.19 |
[SWEA/Python] SW Expert Academy 15612번 - 체스판 위의 룩 배치 (0) | 2022.11.06 |
[BOJ/Python] 백준 5430번 - AC (0) | 2022.11.06 |
Comments