내 맴
[ 백준 ] 14658번 : 하늘에서 별똥별이 빗발친다 (파이썬) 본문
728x90
문제 )
https://www.acmicpc.net/problem/14658
14658번: 하늘에서 별똥별이 빗발친다
첫째 줄에 네 정수 N, M, L, K가 주어진다. (1 ≤ N, M ≤ 500,000, 1 ≤ L ≤ 100,000, 1 ≤ K ≤ 100) N은 별똥별이 떨어지는 구역의 가로길이, M은 세로길이, L은 트램펄린의 한 변의 길이, K는 별똥별의 수를
www.acmicpc.net
[ 풀이 IDEA ]
1. N, M ≤ 500,000 이므로 트램펄린을 한칸씩 옮기는 Brute Force로는 문제를 해결할 수가 없다!
2. 그러나, K<100이기 때문에 K를 이용해서 문제를 풀 것!
- python code
def count_range(x, y):
# 좌표가 범위 내에 있는지 확인
star_cnt = 0
for i in range(k):
star_x, star_y = stars[i][0], stars[i][1]
if (x<=star_x) and (star_x<=x+l) and (y<=star_y) and (star_y<=y+l):
star_cnt += 1
return star_cnt
def solution(n, m, l, k, stars):
max_star = 0
# 좌상단 좌표
for i in range(k):
# 우상단 좌표
for j in range(k):
x, y = stars[i][0], stars[j][1]
# 해당 좌표가 범위 내에 있는지 확인
max_star = max(max_star, count_range(x, y))
return k - max_star
n, m, l, k = map(int, input().split())
# board = [[0]*(n+1) for _ in range(m+1)]
stars = []
for _ in range(k):
star_xy = list(map(int, input().split()))
stars.append(star_xy)
print(solution(n, m, l, k, stars))
728x90
'개발 공부 > Algorithm' 카테고리의 다른 글
[ 백준 ] 3197번 : 백조의 호수 (파이썬) (0) | 2022.12.28 |
---|---|
[ 백준 ] 1987번 : 알파벳 (BFS / 파이썬) (0) | 2022.12.27 |
[ 백준 ] 2667번 : 단지번호 붙이기 (파이썬 / DFS) (1) | 2020.06.20 |
[ 백준 ] 2606번 : 바이러스 (파이썬) (0) | 2020.06.20 |
[ 백준 ] 1260번 : DFS와 BFS (파이썬) (0) | 2020.06.14 |