L1-018. 大笨钟

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;
}

猜你喜欢

转载自blog.csdn.net/qq_37405865/article/details/80218348