일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
Tags
- 관계절
- 영어기초
- from what i hear
- IF
- 파이썬
- 영어 회화
- 백준
- 라이브아카데미
- 다이나믹프로그래밍
- 일상회화
- 회화
- python
- 정렬
- 알고리즘
- dfs
- 라이브 아카데미
- 회화기초
- 영어회와
- 백트래킹
- 전치사
- Hyperledger Fabric
- BFS
- N-Queens
- 내가 듣기로는
- 영어
- 영어회화
- Backtracking Algorithm
- baekjoon
- 백트래킹 알고리즘
- 완전탐색
Archives
- Today
- Total
내 맴
[ 백준 ] 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 > Baekjoon 문제풀이' 카테고리의 다른 글
[ 백준 ] 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 |