本来打算更新之前的算法内容 这两天要进行校内测试耽搁了 才学没多久还是会无脑算法 浅浅上传一下校内选拔的个人做法吧 欢迎大佬指点
内存限制:512.0MB
C/C++时间限制:1.0s
Java时间限制:3.0s
Python时间限制:5.0s
问题描述
给定当前的时间,请用英文的读法将它读出来。
时间用时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
刚看到题时的第一发应:暴力算法 由于对c的不了解刚开始做题时定义的char数组并不是二维数组 后面发现输出结果都只有一个字母 发现了应该要设置二维数组来存储字符串 相应的输出也应改为%s 然后就是不同情况进行判别 分为 (1)h<=20 和 (2) h>20 这两种情况 再对m进行划分 划分出 (1)m>20 (2)m<=20 (3)m==0 三种情况 下面给出代码
#include <cstdio>
#include <iostream>
#include <cstring>
#include <algorithm>
using namespace std;
char normal[21][100]={"zero","one","two","three", "four", "five", "six", "seven", "eight", "nine", "ten", "eleven", "twelve","thirteen", "fourteen","fifteen", "sixteen", "seventeen", "eighteen", "nineteen", "twenty"};
char unnormal[4][100]={"twenty","thirty","forty","fifty"};
int main(){
int h,m;
scanf("%d %d",&h,&m);
if(h<=20){
if(m!=0&&m!=00&&m<=20){
printf("%s %s",normal[h],normal[m]);
}
if(m>20){
int j=m%10;
int i=m/10;
if(m==30||m==40||m==50){
printf("%s %s %s",normal[h],unnormal[i-2]);
}
printf("%s %s %s",normal[h],unnormal[i-2],normal[j]);
}
if(m==0||m==00){
printf("%s o'clock",normal[h]);
}
}
if(h>20){
int a=h%10;
int b=h/10;
if(m!=0&&m!=00&&m<=20){
printf("%s %s %s",unnormal[b-2],normal[a],normal[m]);
}
if(m>20){
int j=m%10;
int i=m/10;
printf("%s %s %s %s",unnormal[b-2],normal[a],unnormal[i-2],normal[j]);
}
if(m==0||m==00){
printf("%s %s o'clock",unnormal[b-2],normal[a]);
}
}
return 0;
}