题目大意:告诉时间,计算三个指针两两间夹角。
思路:乘以18000,然后直接整数计算模拟即可。
ps:因为最后时针乘了5,如果超过六十是要减得,忘记了,wa好多次才发现
#include <iostream>
#include <cstdio>
#include <string>
#include <cstring>
#include <fstream>
#include <algorithm>
#include <cmath>
#include <queue>
#include <stack>
#include <vector>
#include <map>
#include <set>
#include <iomanip>
using namespace std;
#define MAXN 10005
#define MOD 1000000007
#define TT 1800000
int gcd(int a , int b )
{
if(b == 0) return a;
else return gcd(b , a % b);
}
void solve(int h , int m)
{
int sec;
if(h >= m)
sec = (h - m) * 6;
else
sec = (m - h) * 6;
int t = gcd(sec , TT);
if(sec > 180 * TT) sec = 360 * TT - sec;
if(sec % TT) cout << sec / t << "/" << TT / t <<" ";
else cout << sec / TT<<" ";
}
int main()
{
int t ;
string a;
cin >> t ;
while(t--)
{
cin >> a ;
int h , m , s ;
h = ((a[0] - '0') * 10 + (a[1] - '0')) * TT;
if(h > 12*TT) h -= 12 * TT;
m = ((a[3] - '0') * 10 + (a[4] - '0')) * TT;
s = ((a[6] - '0') * 10 + (a[7] - '0')) * TT;
m += s / 60;
h += m / 60;
h *= 5;
if(h > 60*TT) h -= 60 * TT; //至关重要
solve(h , m);
solve(h , s);
solve(m , s);
cout << endl;
}
return 0;
}