Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 | 31 |
Tags
- C
- algorithm
- winapi
- 오블완
- Programmers
- 2294
- C++
- UE5
- RootMotion
- 티스토리챌린지
- UnrealEngine4
- DirectX11
- IFileDialog
- 프로그래머스
- RVO
- 백준
- GeeksForGeeks
- directx
- NRVO
- baekjoon
- softeer
- 1563
- const
- 줄 세우기
- 팰린드롬 만들기
- 언리얼엔진5
- Frustum
- DeferredRendering
- Unreal Engine5
- UnrealEngine5
Archives
- Today
- Total
Game Develop
[Algorithm] Programmers :: 두 원 사이의 정수 쌍 본문
https://school.programmers.co.kr/learn/courses/30/lessons/181187
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
long long solution(int r1, int r2)
{
long long answer = 0;
for (int x = 1; x <= r2; ++x)
{
int minY = ceil(sqrt((long long)r1 * r1 - (long long)x * x));
int maxY = floor(sqrt((long long)r2 * r2 - (long long)x * x));
if (x >= r1) minY = 0;
answer += (maxY - minY + 1);
}
return answer * 4;
}
|
cs |
x^2 + y^2 = r^2 라는 원의 방정식을 이용한 풀이이다.
식을 수정하면 y^2 = r^2 - x^2이며, y = 루트r^2 - x^2이다.
즉, x축에서의 각 최소,최대의 y값을 구해서 그 차를 이용해 두 원 사이의 정수 쌍을 구하는 문제이다.
작은원과 큰 원 사이이기 때문에, minY(작은원에서의 y좌표값)은 반올림해주고 maxY(큰 원에서의 y좌표값)은 반내림 해준다.
그리고 반복문을 1부터 r2까지 (x축 1부터 r2까지) 해준다는것도 중요하다. 0부터하면 겹치는값이 생기기때문에 오버된 값이 나온다. 1부터해야 해당분면에서의 적절한 점의 개수가 나오기 때문에, 하나의 분면에서 구한값 * 4가 정답이 될 수 있다.
잘 이해가 안되면 1사분면에서 1부터 r2까지 점을 찍은다음 그대로 왼쪽으로 90도 회전시켜보면 된다.
'Algorithm > Programmers' 카테고리의 다른 글
[Algorithm] Programmers :: 기지국 설치 (0) | 2023.06.29 |
---|---|
[Algorithm] Programmers :: 스티커 모으기(2) (0) | 2023.06.27 |
[Algorithm] Programmers :: 연속된 부분 수열의 합 (0) | 2023.06.26 |
[Algorithm] Programmers :: 과제 진행하기 (0) | 2023.06.26 |
[Algorithm] Programmers :: 리코쳇 로봇 (0) | 2023.06.17 |