博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
C语言 · 报时助手
阅读量:4654 次
发布时间:2019-06-09

本文共 3077 字,大约阅读时间需要 10 分钟。

基础练习 报时助手  
时间限制:1.0s   内存限制:512.0MB
      
 
锦囊1
  判断,字符串输出。
锦囊2
  按要求输出,判断特殊情况。
 
问题描述
  给定当前的时间,请用英文的读法将它读出来。
  时间用时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
 
代码一:
1 /* 2 0:zero, 1: one, 2:two, 3:three, 4:four, 5:five 3 6:six, 7:seven, 8:eight, 9:nine, 10:ten, 11:eleven 4 12:twelve, 13:thirteen, 14:fourteen, 15:fifteen 5 16:sixteen, 17:seventeen, 18:eighteen, 19:nineteen 6 20:twenty, 30:thirty,40:forty,50:fifty。 7  8 对于大于20小于60的数字,首先读整十的数,然后再加上个位数。 9     如31首先读30再加1的读法,读作“thirty one”。10 按上面的规则:11     21:54读作“twenty one fifty four”;12     9:07读作“nine seven”;13     0:15读作“zero fifteen”。14 */15 #include
16 int main(){ 17 char a[21][20]={
"zero","one","two","three","four","five","six","seven","eight","nine","ten","eleven","twelve","thirteen","fourteen","fifteen","sixteen","seventeen","eighteen","nineteen","twenty"}; 18 char b[6][20]={
"","","twenty","thirty","forty","fifty"};19 int h,m;20 scanf("%d%d",&h,&m);21 if(m==0){ 22 if(h<=20)23 printf("%s o'clock",a[h]);24 else25 printf("%s %s",b[h/10],a[h%10]);26 }else{27 if(h<=20){28 if(m<=20){29 printf("%s %s",a[h],a[m]);30 }else{31 printf("%s %s %s",a[h],b[m/10],a[m%10]); 32 }33 }else{34 if(m<=20){ 35 printf("%s %s %s",b[h/10],a[h%10],a[m]); 36 }else{37 printf("%s %s %s %s",b[h/10],a[h%10],b[m/10],a[m%10]); 38 } 39 } 40 } 41 return 0; 42 }

代码二:

1 #include
2 void ass(int number){ 3 char n[100][100]={
"zero","one","two","three","four","five","six","seven","eight","nine","ten","eleven","twelve","thirteen","fourteen","fifteen","sixteen","seventeen","eighteen","nineteen","twenty", 4 "thirty","forty","fifty"}; 5 int a=number/10; 6 int b=number%10; 7 if(number<=20){ 8 printf("%s",n[number]); 9 }else{10 if(b!=0){11 printf(" %s",n[b]);12 }13 printf("%s",n[number+18]);14 }15 }16 void time_ass(int hour,int minu){17 if(minu==0){
//整点 18 ass(hour);19 printf(" o'clock");20 }else{
//非整点 21 ass(hour);22 printf(" ");23 ass(minu);24 }25 }26 int main(){27 int h,m;28 scanf("%d%d",&h,&m);29 time_ass(h,m);30 return 0;31 }

 

 

转载于:https://www.cnblogs.com/panweiwei/p/6480899.html

你可能感兴趣的文章
基础细节知识
查看>>
树状数组求区间最大值
查看>>
从面试官角度来告诉大家,哪些人能面试成功
查看>>
以我的亲身经历为例,告诉大家写简历和面试的技巧(面向高级开发和架构师)...
查看>>
一个简单的PHP网站结构
查看>>
Redis 学习之简介及安装
查看>>
jsp简单的学习
查看>>
[LeetCode][JavaScript]Number of 1 Bits
查看>>
[LeetCode][JavaScript]Plus One
查看>>
JQ选择器
查看>>
快速排序算法
查看>>
9.Redis 有序集合(sorted set)
查看>>
ios高阶教程 块对象(block)的利用
查看>>
tomcat项目的部署
查看>>
SQLServer2012通过链接服务器执行SQLServer2000的存储过程的问题
查看>>
C语言-06复杂数据类型-01数组
查看>>
查看Python、flask 版本
查看>>
同余方程 2012年NOIP全国联赛提高组
查看>>
vue 图片预览插件
查看>>
深入解析:分布式系统的事务处理经典问题及模型
查看>>