蓝桥杯vip试题 报时助手

简介: 蓝桥杯vip试题 报时助手

问题描述

给定当前的时间,请用英文的读法将它读出来。

  时间用时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

解题代码

import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import java.util.Scanner;
public class Main {
  static Scanner sc = new Scanner(System.in);
  public static void main(String[] args) {
    Map<Integer, String> maps = new HashMap<Integer, String>();
    maps.put(1, "");
    String str = "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";
    String [] strArr = str.split(",");
    for (int i = 0; i < strArr.length; i++) {
      String str2Arr[] = strArr[i].split(":");
      maps.put(Integer.valueOf(str2Arr[0]),str2Arr[1]);
    }
    //输入日期
    int h = sc.nextInt();//小于24(小时)
    int m = sc.nextInt();//小于60(分)
    //判断是否符合规则
    if(h<=24 && m<=60) {
      String strH="";
      String strM="";
      if(h<=20) {
        strH = maps.get(h);
      }else if(h>20) {
        strH = maps.get(20) +" "+ maps.get(h-20);
      }
      //如果是整数就直接返回
      if(m==20 || m==30 || m==40 || m==50) {
        strM = maps.get(m);
      }else if(m<20) {
        //m=19?
        strM = maps.get(m);
      }else if(m>20 && m<30) {
        //m=29?
        //29-20=9
        strM = maps.get(20)+" " + maps.get(m-20);
      }else if(m>30 && m<40) {
        //m=329?
        //39-30=9
        strM = maps.get(30)+" " + maps.get(m-30);
      }else if(m>40 && m<50) {
        //m=49?
        //49-40=9
        strM = maps.get(40)+" " + maps.get(m-40);
      }else if(m>50 && m<60) {
        //m=59?
        //59-50=9
        strM = maps.get(50) +" "+ maps.get(m-50);
      }
      System.out.println(strH+" "+strM);
    }
//    for (Integer key : maps.keySet()) {
//      System.out.println(key+"--->"+maps.get(key));
//    }
  }
}


目录
相关文章
|
8月前
|
人工智能 算法 Java
第十三届蓝桥杯B组Java(试题C:字符统计)
第十三届蓝桥杯B组Java(试题C:字符统计)
110 0
|
3月前
|
人工智能 Python
蓝桥杯练习题(四):Python组之历届试题三十题
关于蓝桥杯Python组历届试题的三十个练习题的总结,包括题目描述、输入输出格式、样例输入输出以及部分题目的解题思路和代码实现。
64 0
蓝桥杯练习题(四):Python组之历届试题三十题
|
8月前
|
机器学习/深度学习 人工智能 算法
2024 蓝桥杯本科B组试题
2024 蓝桥杯本科B组试题
142 0
蓝桥杯Java-B组2015年试题解题笔记
蓝桥杯Java-B组2015年试题解题笔记
|
数据格式
蓝桥杯Java-B组2014年试题解题笔记(下)
蓝桥杯Java-B组2014年试题解题笔记(下)
|
8月前
|
算法 Java C语言
第十四届蓝桥杯集训——练习解题阶段(无序阶段)-ALGO-940 试题3971
第十四届蓝桥杯集训——练习解题阶段(无序阶段)-ALGO-940 试题3971
69 0
|
8月前
|
Java C语言 C++
第十四届蓝桥杯集训——练习解题阶段(无序阶段)-试题 基础练习 十六进制转八进制
第十四届蓝桥杯集训——练习解题阶段(无序阶段)-试题 基础练习 十六进制转八进制
50 0
|
8月前
|
算法 Java C语言
第十四届蓝桥杯集训——练习解题阶段(无序阶段)-试题 基础练习 数列排序(四种语言对照)
第十四届蓝桥杯集训——练习解题阶段(无序阶段)-试题 基础练习 数列排序(四种语言对照)
55 0
|
8月前
|
Python
第十三届蓝桥杯B组python(试题A:排列字母)
第十三届蓝桥杯B组python(试题A:排列字母)
72 0
|
8月前
|
Java
第十三届蓝桥杯B组Java(试题B:山)
第十三届蓝桥杯B组Java(试题B:山)
72 0