728x90
728x90
문제

과거 이집트인들은 각 변들의 길이가 3, 4, 5인 삼각형이 직각 삼각형인것을 알아냈다. 주어진 세변의 길이로 삼각형이 직각인지 아닌지 구분하시오.
입력
입력은 여러개의 테스트케이스로 주어지며 마지막줄에는 0 0 0이 입력된다. 각 테스트케이스는 모두 30,000보다 작은 양의 정수로 주어지며, 각 입력은 변의 길이를 의미한다.
출력
각 입력에 대해 직각 삼각형이 맞다면 "right", 아니라면 "wrong"을 출력한다.
예제 입력 1
6 8 10 25 52 60 5 12 13 0 0 0
예제 출력 1
right wrong right
출처
Contest > Waterloo's local Programming Contests > 2 October, 2010 A번
알고리즘 분류
- 수학
- 기하학
- 피타고라스 정리
문제 출처
https://www.acmicpc.net/problem/4153
4153번: 직각삼각형
입력은 여러개의 테스트케이스로 주어지며 마지막줄에는 0 0 0이 입력된다. 각 테스트케이스는 모두 30,000보다 작은 양의 정수로 주어지며, 각 입력은 변의 길이를 의미한다.
www.acmicpc.net
문제 해결 방법
- 피타고라스 정리를 이용하면 쉽게 풀 수 있었던 문제였다.
-
- : 가장 긴 변의 길이
- : 나머지 변의 길이
-
코드
#include <iostream> #include <cmath> #include <vector> #include <algorithm> using namespace std; int a, b, c; vector<int> nums; int main() { ios_base::sync_with_stdio(false); cin.tie(NULL); cout.tie(NULL); while (1) { cin >> a >> b >> c; if (!a && !b && !c) { // 0 입력 받으면 반복문 빠져 나오기 break; } nums.push_back(a); nums.push_back(b); nums.push_back(c); sort(nums.begin(), nums.end()); // 오름 차순 정렬 if (pow(nums[2], 2) == pow(nums[1], 2) + pow(nums[0], 2)) { // A² = B² + C² cout << "right" << '\n'; } else { cout << "wrong" << '\n'; } nums.clear(); // 벡터 비워주기 } return 0; }
채점 결과

참고
- [단계별로 풀어보기] > [기하 1]
- 브론즈III
728x90
728x90
'Problem Solving > BOJ' 카테고리의 다른 글
[BOJ-1004][C++] 어린 왕자 (0) | 2022.11.12 |
---|---|
[BOJ-1002][C++] 터렛 (0) | 2022.11.10 |
[BOJ-3053][C++] 택시 기하학 (0) | 2022.11.10 |
[BOJ-2477][C++] 참외밭 (0) | 2022.11.10 |
[BOJ-3009][C++] 네 번째 점 (0) | 2022.11.10 |
[BOJ-1085][C++] 직사각형에서 탈출 (0) | 2022.11.10 |
[BOJ-4358][C++] 생태학 (0) | 2022.11.09 |
[BOJ-11478][C++] 서로 다른 부분 문자열의 개수 (0) | 2022.11.09 |