zoukankan      html  css  js  c++  java
  • 【JAVA】(vip)蓝桥杯试题 基础练习 报时助手 BASIC-26 JAVA

    试题 基础练习 报时助手

    资源限制
    时间限制:1.0s 内存限制:512.0MB

    问题描述
      给定当前的时间,请用英文的读法将它读出来。
      时间用时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.Scanner;
    
    public class TimeReportingAssistant {
        public static void main(String[] args) {
            Scanner sc = new Scanner(System.in);
            // 输入包含两个非负整数h和m,表示时间的时和分。
            // 非零的数字前没有前导0。h小于24,m小于60。
            int h = sc.nextInt();
            int m = sc.nextInt();
            sc.close();
    
            if (m == 0) {
                System.out.println(English(h) + " " + "o'clock");
            } else {
                System.out.println(English(h) + " " + English(m));
            }
        }
    
        public static String English(int x) {
            String[] strArray = {"zero", "one", "two", "three", "four", "five",
                    "six", "seven", "eight", "nine", "ten", "eleven", "twelve", "thirteen",
                    "fourteen", "fifteen", "sixteen", "seventeen", "eighteen", "nineteen", "twenty"};
            String x1;
            if (x <= 20) {
                x1 = strArray[x];
            } else if (x < 30) {
                x1 = "twenty" + " " + strArray[x % 20];
            } else if (x == 30) {
                x1 = "thirty";
            } else if (x < 40) {
                x1 = "thirty" + " " + strArray[x % 30];
            } else if (x == 40) {
                x1 = "forty";
            } else if (x < 50) {
                x1 = "forty" + " " + strArray[x % 40];
            } else if (x == 50) {
                x1 = "thirty";
            } else {
                x1 = "fifty" + " " + strArray[x % 50];
            }
    
            return x1;
        }
    }
    
  • 相关阅读:
    botzone Tetris2
    NOIP2017游记
    城乡联谊胡策会糊厕R3
    SRM 20
    AtCoder Regular Contest 082
    AtCoder Grand Contest 019
    复数模版
    SRM13
    NOI2017&&codeM2017游记
    java多线程编程
  • 原文地址:https://www.cnblogs.com/DreamingFishZIHao/p/12982963.html
Copyright © 2011-2022 走看看