当前位置:   article > 正文

华为OD机试C卷“警察解密时间”字符串排序Java解答

华为OD机试C卷“警察解密时间”字符串排序Java解答

描述

示例

算法思路1

答案1

  1. import java.util.*;
  2. public class Main {
  3. public static void main(String[] args) {
  4. Scanner scanner = new Scanner(System.in);
  5. while(true){
  6. System.out.println("请输入一个时间,格式为hh:mm");
  7. String input = scanner.nextLine();
  8. String [] tokens = input.split("[:|:]");
  9. int hour = Integer.parseInt(tokens[0]);
  10. int minute = Integer.parseInt(tokens[1]);
  11. if(hour>23||minute>59||hour<0||minute<0){
  12. System.out.println("时间输出错误,请重新输入:");
  13. }else{
  14. System.out.print("解密后的时间为:");
  15. GetTime(hour,minute);
  16. }
  17. }
  18. }
  19. private static void GetTime(int hour, int minute) {
  20. int [] digits={hour/10,hour%10,minute/10,minute%10};//依次获得每位数字
  21. Arrays.sort(digits);
  22. for(int i=0;i<4;i++) {
  23. if (digits[i] >= minute / 10) {//如果分钟找到比它大且合法的值,则小时不变
  24. for (int j = 0; j < 4; j++) {
  25. if (((digits[i] * 10 + digits[j]) > minute) && (digits[i] * 10 + digits[j]) < 60) {
  26. if(digits[i]==0){//分钟是0几,例18:03
  27. System.out.println(hour + ":0" + (digits[i] * 10 + digits[j]));
  28. }else if(hour<10){
  29. System.out.println("0"+hour + ":" + (digits[i] * 10 + digits[j]));
  30. }else{
  31. System.out.println(hour + ":" + (digits[i] * 10 + digits[j]));
  32. }
  33. System.exit(0);
  34. }
  35. }
  36. }
  37. }
  38. for(int i=0;i<4;i++) {
  39. if(hour/10==0){//如果分钟没有比他大的就找时钟比他大点,分钟取最小
  40. for (int k = 1; k < 4; k++) {
  41. if (digits[k] >0&&digits[k]<3) {
  42. System.out.println(digits[k]*10+":00");
  43. System.exit(0);
  44. }
  45. }
  46. }else if(digits[i]==hour/10){//小时>10
  47. for (int k = 1; k < 4; k++) {
  48. if (((digits[i] * 10 + digits[k]) > hour) && (digits[i] * 10 + digits[k]) < 24) {
  49. if(digits[0]==0){//20:22
  50. System.out.println((digits[i] * 10 + digits[k]) + ":00" );
  51. }else{
  52. System.out.println((digits[i] * 10 + digits[k]) + ":" + (digits[0] * 10 + digits[0]));
  53. }
  54. System.exit(0);
  55. }
  56. }
  57. }
  58. }
  59. for(int i=0;i<4;i++){//时钟没有比他大的了,则是下一天了,那么就找时钟分钟都最小的
  60. System.out.println((digits[0]*10+digits[0])+":"+(digits[0]*10+digits[0]));
  61. System.exit(0);
  62. }
  63. }
  64. }

详解1

同志们!注意0啊啊啊,我有点不太会写0的情况只能硬考虑情况了,所以欢迎评论区的小伙伴们批评指正

String [] tokens = input.split("[:|:]");

split() 方法是 Java 中 String 类的一个方法,用于将一个字符串根据指定的分隔符进行分割,并返回一个包含分割后子字符串的字符串数组。

其语法为:

public String[] split(String regex)

其中,regex 是一个正则表达式,用于指定分隔符。split() 方法会根据 regex 将调用它的字符串分割成多个子字符串,并将这些子字符串存储在一个字符串数组中。

在上面的代码示例中,split() 方法被用于将用户输入的时间字符串根据冒号(":")或逗号(",")进行分割。为了匹配多个可能的分隔符,正则表达式"[:|,]"被使用,其中[:|,]表示冒号或逗号。

例如,如果用户输入的是 "12:34",那么split() 方法会将这个字符串分割成两个子字符串:"12" 和 "34"。如果用户输入的是 "12,34",同样会被分割成相同的两个子字符串。

这样,通过split()方法的使用,程序能够灵活地处理不同的用户输入格式,从而更好地满足需求。

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/从前慢现在也慢/article/detail/240813
推荐阅读
相关标签
  

闽ICP备14008679号