• hdu_5705_Clock("巴卡斯杯" 中国大学生程序设计竞赛


    题目连接:http://acm.hdu.edu.cn/showproblem.php?pid=5705

    题意:给你一个时间和一个角度,问你下一个时针和分针形成给出的角度是什么时候

    题解:我们可以将这个问题看成追及问题,考虑时针:每小时30°,每分钟1/2°,每秒1/120°,考虑分针:没分钟6°,每秒1/10°,如果我把全部同时乘一个120,不就能避免精度造成的问题了吗!现在再来考虑时针和分针的位置情况:这里我们以分针按顺时针的方向到时针


    1:当时针和分针的θ∠大于180*120时(1)当(360*120-θ)大于给出的角度an时,需要的时间ans=h+(θ-an*120)/11,/11是因为每秒钟时针走1°,分针走12°。(2)当(360*120-θ)小于给出的角度an时,需要的时间ans=h+(θ-(360-an)*120)/11

    2:当时针和分针的θ∠小于180*120时(1)当(360*120-θ)大于给出的角度an时,需要的时间ans=h+(θ-an*120)/11。(2)当(360*120-θ)小于给出的角度an时,需要的时间ans=h+(θ+an*120)/11。

    最后再根据经过的时间算出当前的时间

     1 #include<cstdio>
     2 int hh,mm,ss,ic=1,h,m,s,an,d,ans,mo=120*360,mod=120*180;
     3 void fuck(){
     4     s++,h=(3600*h+m*60+s)%mo,m=(m*720+12*s)%mo,d=(h+mo-m)%mo;
     5     if(d>=mod)if(an*120<mo-d)ans=h+(d-an*120)/11;else ans=h+(d-(360-an)*120)/11;
     6     else if(an*120<=d)ans=h+(d-an*120)/11;else ans=h+(d+an*120)/11;
     7 }
     8 int main(){
     9     while(~scanf("%d:%d:%d%d",&h,&m,&s,&an))
    10     fuck(),printf("Case #%d: %02d:%02d:%02d
    ",ic++,ans/3600%12,ans/60%60,ans%60);
    11     return 0;
    12 }
    View Code



  • 相关阅读:
    Java入门
    Java入门
    字符串常用方法(转载--https://www.cnblogs.com/ABook/p/5527341.html)
    SSM-8FastDfs搭建
    SSM7-nginx的反向代理和负载均衡
    SSM-6nginx Linux下的安装
    SSM-5zookeeper在LINUX上自启
    SSM4-Linux上jdk、tomcat、zookeeper------tar zxvf的安装
    SSM3-SVN的安装和搭建环境
    SSM2-搭建maven常见的错误以及解决方法
  • 原文地址:https://www.cnblogs.com/bin-gege/p/5696125.html
Copyright © 2020-2023  润新知