반응형
https://www.acmicpc.net/problem/1002
문제 설명
두 좌표 (x1, y1)와 (x2, y2)가 주어지고, 목표점과의 거리 r1, r2가 주어질 때
목표점이 존재할 수 있는 좌표의 수를 구하는 문제이다.
풀이 과정
이 문제는 고등학교 교과과정에서 배웠던 원의 방정식 중 두 원의 교점을 활용하는 문제이다.
먼저, 원이라는 것은 하나의 정점으로부터 같은 거리를 가지는 점들의 집합이므로
정점(x1, y1)로 부터 거리 r1을 가진 점들은 원으로 존재할 것이고
정점(x2, y2)로 부터 거리 r2을 가진 점들은 원으로 존재할 것이기 때문이다.
두 원은 다음과 같은 관계로 존재할 수 있다.
위의 경우들을 다음과 같이 코드로 표현하면 되는 문제이다.
import math
t = int(input())
for i in range(t):
x1, y1, r1, x2, y2, r2 = map(int, input().split())
dist = math.sqrt((x1 - x2)**2 + (y1-y2)**2)
if x1 == x2 and y1 == y2: # 두 원의 중심이 같을 때
if r1 == r2: # 반지름이 같으면 : 같은 원
print(-1)
else:
print(0) # 다르면 영원히 만나지 않음
else: # 두 원의 중심이 다를 때
if abs(r1-r2) == dist or r1 + r2 == dist: # 내접원 or 외접원
print(1)
elif abs(r1-r2) < dist < r1 + r2: # 두 점에서 만날 때
print(2)
else: # 만나지 않음
print(0)
전체 문제 & 코드는 위의 깃에 정리되어 있습니다.
팔로우 & 맞팔은 환영입니다 !
반응형
'Algorithm > Implementation' 카테고리의 다른 글
[백준] 18870 좌표 압축 (Python 파이썬) (0) | 2021.10.02 |
---|---|
[백준] 2108 통계학 (Python 파이썬) (0) | 2021.10.02 |
[백준] 9020 골드바흐의 추측 (Python 파이썬) (0) | 2021.10.02 |
[백준] 4948 베르트랑 공준 (Python 파이썬) (0) | 2021.10.01 |
[백준] 1929 소수 구하기 (Python 파이썬) (0) | 2021.10.01 |