시와 분이라는 두 개의 숫자가 있다고 가정합니다. 시침과 분침 사이에 형성된 더 작은 각도(60진수 단위)를 찾아야 합니다. 따라서 입력이 hour =12 및 min :=30인 경우 결과는 165°가 됩니다.
이 문제를 해결하기 위해 다음 단계를 따릅니다. −
-
h =12이면 h :=0
을 설정합니다. -
m =60이면 m :=0으로 설정
-
hAngle :=0.5 * (60h) + m
-
mAngle:=6m
-
ret :=|hAngle - mAngle|
-
ret의 최소값을 반환하고 (360 – ret)
예시(C++)
이해를 돕기 위해 다음 구현을 살펴보겠습니다. −
#include <bits/stdc++.h> using namespace std; class Solution { public: double angleClock(int h, int m) { if(h == 12) h = 0; if(m == 60) m = 0; double hAngle = 0.5*((60 * h) + m); double mAngle = 6 * m; double ret = abs(hAngle - mAngle); return min(360 - ret, ret); } }; main(){ Solution ob; cout << (ob.angleClock(12, 30)); }
입력
12 30
출력
165.00000