报时助手
问题描述
给定当前的时间,请用英文的读法将它读出来。
时间用时h和分m表示,在英文的读法中,读一个时间的方法是:
如果m为0,则将时读出来,然后加上“o’clock”,如3:00读作“three o’clock”。
如果m不为0,则将时读出来,然后将分读出来,如5:30读作“five thirty”。
时和分的读法使用的是英文数字的读法,其中0~20读作:
0:zero, 1: one, 2:two, 3:three, 4:four, 5:five, 6:six, 7:seven, 8:eight, 9:nine, 10:ten, 11:eleven, 12:twelve, 13:thirteen, 14:fourteen, 15:fifteen, 16:sixteen, 17:seventeen, 18:eighteen, 19:nineteen, 20:twenty。
30读作thirty,40读作forty,50读作fifty。
对于大于20小于60的数字,首先读整十的数,然后再加上个位数。如31首先读30再加1的读法,读作“thirty one”。
按上面的规则21:54读作“twenty one fifty four”,9:07读作“nine seven”,0:15读作“zero fifteen”。
输入格式
输入包含两个非负整数h和m,表示时间的时和分。非零的数字前没有前导0。h小于24,m小于60。
输出格式
输出时间时刻的英文。
样例输入
0 15
样例输出
zero fifteen
本题的一大难点是0-60的英文单词选取哪种数据结构来存储,以及如何将数量不小的单词存入数据结构之中。本题我采用的方法比较暴力,将0-19,20,30,40,50存入数组。然而数组的初始化不能过多,我被这个问题困扰了很久,而后我想到将数组升为二维数组,这样初始化项过多的问题就解决了
#include<iostream>
using namespace std;
int main()
{
int h,m,a,b;//a代表两位数十位数字,b代表两位数个位数字
cin >> h >> m;
char hour[24][24] = {"zero","one","two","three","four","five","six","seven","eight","nine","ten","eleven","twelve","thirteen","fourteen","fifteen","sixteen","seventeen","eighteen","nineteen"};
char minute[24][24] = {"o'clock","one","two","three","four","five","six","seven","eight","nine","ten","eleven","twelve","thirteen","fourteen","fifteen","sixteen","seventeen","eighteen","nineteen"};
char ten[10][10] = {"","","twenty","thirty","forty","fifty"};
if(h < 20)
cout << hour[h] << " ";
else{
a = h / 10;
b = h % 10;
cout << ten[a] << " ";
if(b != 0)
cout << hour[b] << " ";
}
if(m < 20)
cout << minute[m];
else{
a = m / 10;
b = m % 10;
cout << ten[a] << " " ;
if(b != 0)
cout<< minute[b] << " ";
}
return 0;
}
本题中,我的测试用例仍然较为特殊。应当按照正常数据,错误数据,边界数据来全面的测试代码,这样才能及早的发现代码的错误与缺陷。