题目地址:http://acm.hdu.edu.cn/showproblem.php?pid=2076
思路:都取相对于12点转过的角度
AC代码:
#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <algorithm>
#include <queue>
#include <stack>
#include <map>
#include <cstring>
#include <climits>
#include <cmath>
#include <cctype>
const int inf = 0x3f3f3f3f;//1061109567
typedef long long LL;
#define lson l,m,rt<<1
#define rson m+1,r,rt<<1|1
using namespace std;
int main()
{
int t;
scanf("%d",&t);
while(t--)
{
int h,m,s;
scanf("%d%d%d",&h,&m,&s);
h %= 12;
double sum1 = h * 30.0 + 0.5 * m + s / 120.0;
double sum2 = m * 6.0 + s / 10.0;
double sum3 = abs(sum1 - sum2);
if(sum3 > 180)
sum3 = 360 - sum3;
int sum4 = (int)sum3;
printf("%d\n",sum4);
}
return 0;
}