Sponsored
Sponsored
This approach involves calculating the angles made by the hour hand and the minute hand with respect to 12:00 and then finding the smallest angle between them. The minute hand moves 6 degrees per minute (360 degrees / 60 minutes), and the hour hand moves 30 degrees per hour (360 degrees / 12 hours) plus an additional 0.5 degrees per minute. The difference between these angles gives us the desired result.
Time Complexity: O(1) - The computation involves a fixed number of arithmetic operations.
Space Complexity: O(1) - No additional space is required beyond fixed-size variables.
1#include <iostream>
2#include <cmath>
3
4class Solution {
5public:
6 double angleClock(int hour, int minutes) {
7 double minute_angle = minutes * 6;
8 double hour_angle = (hour % 12) * 30 + minutes * 0.5;
9 double angle = fabs(minute_angle - hour_angle);
10 return angle > 180 ? 360 - angle : angle;
11 }
12};
13
14int main() {
15 Solution sol;
16 std::cout << std::fixed << sol.angleClock(12, 30) << std::endl; // Output: 165.00000
17 std::cout << std::fixed << sol.angleClock(3, 30) << std::endl; // Output: 75.00000
18 std::cout << std::fixed << sol.angleClock(3, 15) << std::endl; // Output: 7.50000
19 return 0;
20}
The C++ solution employs a similar logic to the C solution, encapsulated in a class structure for encapsulation. It uses fixed point notation for output format. The method calculates angles for the hour and minute hands, determines the absolute difference, and computes the smallest angle.
This alternative approach converts the movement of the clock hands into their equivalent rotations, effectively translating this into angles. The goal is to determine the position of both hands as angles relative to the 12 o'clock position and compute the minimal angular difference.
Time Complexity: O(1) - Fixed-time operations based on input.
Space Complexity: O(1) - Uses a constant number of variables.
1
The C solution adjusts the total time into minutes, facilitating the computation of angles directly based on the total elapsed minutes. This methodology leverages modular arithmetic to find positions relative to whole-hour and half-hour rotations, ultimately returning the minimal calculated angle.