L1-018. 大笨钟
时间限制
400 ms
内存限制
65536 kB
代码长度限制
8000 B
判题程序
Standard
作者
陈越
微博上有个自称“大笨钟V”的家伙,每天敲钟催促码农们爱惜身体早点睡觉。不过由于笨钟自己作息也不是很规律,所以敲钟并不定时。一般敲钟的点数是根据敲钟时间而定的,如果正好在某个整点敲,那么“当”数就等于那个整点数;如果过了整点,就敲下一个整点数。另外,虽然一天有24小时,钟却是只在后半天敲1~12下。例如在23:00敲钟,就是“当当当当当当当当当当当”,而到了23:01就会是“当当当当当当当当当当当当”。在午夜00:00到中午12:00期间(端点时间包括在内),笨钟是不敲的。
下面就请你写个程序,根据当前时间替大笨钟敲钟。
输入格式:
输入第一行按照“hh:mm”的格式给出当前时间。其中hh是小时,在00到23之间;mm是分钟,在00到59之间。
输出格式:
根据当前时间替大笨钟敲钟,即在一行中输出相应数量个“Dang”。如果不是敲钟期,则输出:
Only hh:mm. Too early to Dang.
其中“hh:mm”是输入的时间。
输入样例1:19:05输出样例1:
DangDangDangDangDangDangDangDang输入样例2:
07:05输出样例2:
Only 07:05. Too early to Dang.
#include<iostream> #include<iomanip> #include<cstdio> using namespace std; double bizhi(char *num,int length){ //计算包含2的个数与其位数的比值 double answer=0; int numOfTwo=0; for(int i=0;i<length;i++){ if(num[i]=='2') numOfTwo++; } if(num[0]=='-'){ length--; answer=(double)numOfTwo/(double)length; answer*=1.5; if(num[length]%2==0) answer*=2.0; } else{ answer=(double)numOfTwo/(double)length; if(num[length-1]%2==0) answer*=2.0; } return answer; } int main(){ char N[100]; gets(N); int length=0; while(N[length]!='\0'){ length++; } //难点:四舍五入 //方法是将小数放大要保留小数位的十次方倍后加0.5(如果要保留的下一位大于5,这时候就会进位) ,再将其除回去 int x=(int)(bizhi(N,length)*10000+0.5); printf("%.2lf%\n",x/100.0); return 0; }