华为OD刷题C卷 - 每日刷题 21(按身高和体重排队,解密犯罪时间)

2024-06-10 15:04

本文主要是介绍华为OD刷题C卷 - 每日刷题 21(按身高和体重排队,解密犯罪时间),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

三段代码分别解决了三个不同的算法问题,下面是对它们的概述:

1、(按身高和体重排队):

这段代码是解决“按身高和体重排队”的问题。它提供了一个Java类Main,其中包含main方法,用于根据学生的身高和体重对学生进行排序,并输出排序后的学生编号。

main方法首先读取学生数量n,然后读取每个学生的身高和体重,存储到HashMap中。接着,使用StringJoiner来构建最终的排序结果字符串。通过流排序,首先按身高升序排序,身高相同的情况下按体重升序排序,体重也相同的情况下按学生编号升序排序。

2、(按身高体重排序 - 优化版):

这段代码是解决“按身高体重排序”问题的优化版本。它提供了一个Java类Main,其中包含main方法和一个内部类Student,用于对学生进行身高和体重的综合排序。

main方法首先读取学生数量n,然后读取所有学生的身高和体重,创建Student对象数组。接着,使用Arrays.sortStudent数组进行排序,排序规则是:优先按身高升序、身高相同按体重升序、体重也相同的情况下按学生编号升序。

3、(解密犯罪时间):

这段代码是解决“解密犯罪时间”的问题。它提供了一个Java类Main,其中包含main方法和getResult方法,用于根据给定的时间字符串,找出所有可能的合法时间,并输出距离给定时间最近的下一个时间。

main方法首先读取原始时间字符串,然后调用getResult方法并打印解密后的时间。

getResult方法首先使用HashSet来存储时间字符串中出现过的所有数字,然后使用回溯法进行全排列,生成所有可能的合法时间字符串。使用正则表达式来验证排列结果是否为合法的时间格式。最后,将所有合法时间字符串排序,并找出距离给定时间最近的下一个时间。

三段代码都展示了基本的排序和搜索算法思想:第一段和第二段代码通过自定义排序规则来解决学生的排序问题,其中第二段代码提供了一个更面向对象的解决方案;第三段代码则通过全排列和正则表达式来解决时间解密问题。三者都通过精心设计的逻辑来优化性能和解决问题。

package OD301;import java.util.*;/*** @description 按身高和体重排队* @level 6*//*** 题目描述* 某学校举行运动会,学生们按编号(1、2、3…n)进行标识,现需要按照身高由低到高排列,对身高相同的人,按体重由轻到重排列;对于身高体重都相同的人,维持原有的编号顺序关系。请输出排列后的学生编号。* <p>* 输入描述* 两个序列,每个序列由n个正整数组成(0 < n <= 100)。第一个序列中的数值代表身高,第二个序列中的数值代表体重。* <p>* 输出描述* 排列结果,每个数值都是原始序列中的学生编号,编号从1开始*/
// 注意类名必须为 Main, 不要有任何 package xxx 信息
public class Main {public static void main(String[] args) {Scanner sc = new Scanner(System.in);//学生数量int n = sc.nextInt();//身高 <学生编号,身高>Map<Integer, Integer> height = new HashMap<>();for (int i = 0; i < n; i++) {height.put(i + 1, sc.nextInt());}//体重 <学生编号,身高>Map<Integer, Integer> weight = new HashMap<>();for (int i = 0; i < n; i++) {weight.put(i + 1, sc.nextInt());}//先按身高排序,身高相同按体重,体重相同按编号,结果放进StringJoiner中StringJoiner sj = new StringJoiner(" ");height.keySet().stream().sorted((o1, o2) -> {int h1 = height.get(o1);int h2 = height.get(o2);int w1 = weight.get(o1);int w2 = weight.get(o2);if(h1 != h2){return h1 - h2;} else if (h1 == h2 && w1 != w2) {return w1 - w2;}else {return o1 - o2;}}).forEach(s -> {sj.add(Integer.toString(s));});//打印结果System.out.println(sj.toString());}
}package OD301.better;import java.util.Arrays;
import java.util.Scanner;/*** @description 按身高体重排序* @level* @score* @url*/
// 注意类名必须为 Main, 不要有任何 package xxx 信息
public class Main {public static void main(String[] args) {Scanner sc = new Scanner(System.in);//学生个数int n = Integer.parseInt(sc.nextLine());Student[] students = new Student[n];//身高int[] heights = Arrays.stream(sc.nextLine().split(" ")).mapToInt(Integer::parseInt).toArray();//体重int[] weights = Arrays.stream(sc.nextLine().split(" ")).mapToInt(Integer::parseInt).toArray();;for (int i = 0; i < n; i++) {//编号从1开始students[i] = new Student(i + 1, heights[i], weights[i]);}//排序:优先身高升序、身高相同按体重升序、都相同按编号升序Arrays.sort(students, (s1, s2) -> {if (s1.height != s2.height) {return s1.height - s2.height;}if (s1.weight != s2.weight) {return s1.weight - s2.weight;}return s1.id - s2.id;});//输出for (Student student : students) {System.out.print(student.id + " ");}}static class Student {//学生编号int id;//身高int height;//体重int weight;public Student(int id, int height, int weight) {this.id = id;this.height = height;this.weight = weight;}}}
package OD314;import java.util.*;
import java.util.regex.Matcher;
import java.util.regex.Pattern;/*** @description 解密犯罪时间* @level 5* @score 100*//*** 题目描述* 警察在侦破一个案件时,得到了线人给出的可能犯罪时间,形如 “HH:MM” 表示的时刻。* <p>* 根据警察和线人的约定,为了隐蔽,该时间是修改过的,* <p>* 解密规则为:利用当前出现过的数字,构造下一个距离当前时间最近的时刻,则该时间为可能的犯罪时间。* <p>* 每个出现数字都可以被无限次使用。* <p>* 输入描述* 形如HH:SS字符串,表示原始输入。* <p>* 输出描述* 形如HH:SS的字符串,表示推理处理的犯罪时间。* <p>* 备注* 1.可以保证现任给定的字符串一定是合法的。* <p>* 例如,“01:35”和“11:08”是合法的,“1:35”和“11:8”是不合法的。* <p>* 2.最近的时刻可能在第二天。*/
// 注意类名必须为 Main, 不要有任何 package xxx 信息
public class Main {public static void main(String[] args) {Scanner sc = new Scanner(System.in);String[] times = sc.nextLine().split(":");String hour = times[0];String minute = times[1];System.out.println(getResult(hour, minute));}//返回下一个距离最近的时间public static String getResult(String hour, String minute) {//存放时间字符,去重Set<Character> set = new HashSet<>();for (int i = 0; i < hour.length(); i++) {set.add(hour.charAt(i));}for (int i = 0; i < minute.length(); i++) {set.add(minute.charAt(i));}//把字符转为char[]Character[] arr = set.toArray(new Character[0]);//存放满足时间格式的结果ArrayList<String> res = new ArrayList<>();//存放当前排列结果LinkedList<Character> path = new LinkedList<>();dfs(arr, path, res);//把满足时间格式的结果升序排列res.sort(String::compareTo);//找到当前时间 在res里面的下标int index = res.indexOf(hour + minute);String recentTime = "";//如果当前的时间是当前组合的最后一个,则下一个时间是第二天的开头if (index == res.size() - 1) {recentTime = res.get(0);} else {recentTime = res.get(index + 1);}//插入 :recentTime = recentTime.substring(0, 2) + ":" + recentTime.substring(2);return recentTime;}//递归,求当前时间的全排列,每个数字可以无限次使用/*** 返回当前时间的全排列** @param arr  组成当前时间的字符列表* @param path 当前的排列* @param res  结构的排列* @return void* @create 2024/3/21 19:24*/public static void dfs(Character[] arr, LinkedList<Character> path, ArrayList<String> res) {//返回上一层标志 path.length=4if (path.size() == 4) {StringBuilder sb = new StringBuilder();for (Character c : path) {sb.append(c);}String timeStr = sb.toString();//判断该排列是否是合法时间Pattern p = Pattern.compile("([01][0-9]|2[0-3])([0-5][0-9])");Matcher m = p.matcher(timeStr);if (m.find()) {res.add(timeStr);}//返回上一层return;}//全排列for (Character c : arr) {//第i个字符开头,后面全排列,字符可以重复使用path.add(c);dfs(arr, path, res);//因为数字可以无限次使用,所有开始下一个字符的时候,需要清除上一个path.removeLast();}}}

这篇关于华为OD刷题C卷 - 每日刷题 21(按身高和体重排队,解密犯罪时间)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/1048494

相关文章

C# LiteDB处理时间序列数据的高性能解决方案

《C#LiteDB处理时间序列数据的高性能解决方案》LiteDB作为.NET生态下的轻量级嵌入式NoSQL数据库,一直是时间序列处理的优选方案,本文将为大家大家简单介绍一下LiteDB处理时间序列数... 目录为什么选择LiteDB处理时间序列数据第一章:LiteDB时间序列数据模型设计1.1 核心设计原则

MySQL按时间维度对亿级数据表进行平滑分表

《MySQL按时间维度对亿级数据表进行平滑分表》本文将以一个真实的4亿数据表分表案例为基础,详细介绍如何在不影响线上业务的情况下,完成按时间维度分表的完整过程,感兴趣的小伙伴可以了解一下... 目录引言一、为什么我们需要分表1.1 单表数据量过大的问题1.2 分表方案选型二、分表前的准备工作2.1 数据评估

MySQL中DATE_FORMAT时间函数的使用小结

《MySQL中DATE_FORMAT时间函数的使用小结》本文主要介绍了MySQL中DATE_FORMAT时间函数的使用小结,用于格式化日期/时间字段,可提取年月、统计月份数据、精确到天,对大家的学习或... 目录前言DATE_FORMAT时间函数总结前言mysql可以使用DATE_FORMAT获取日期字段

SpringBoot实现RSA+AES自动接口解密的实战指南

《SpringBoot实现RSA+AES自动接口解密的实战指南》在当今数据泄露频发的网络环境中,接口安全已成为开发者不可忽视的核心议题,RSA+AES混合加密方案因其安全性高、性能优越而被广泛采用,本... 目录一、项目依赖与环境准备1.1 Maven依赖配置1.2 密钥生成与配置二、加密工具类实现2.1

Python标准库datetime模块日期和时间数据类型解读

《Python标准库datetime模块日期和时间数据类型解读》文章介绍Python中datetime模块的date、time、datetime类,用于处理日期、时间及日期时间结合体,通过属性获取时间... 目录Datetime常用类日期date类型使用时间 time 类型使用日期和时间的结合体–日期时间(

解密SQL查询语句执行的过程

《解密SQL查询语句执行的过程》文章讲解了SQL语句的执行流程,涵盖解析、优化、执行三个核心阶段,并介绍执行计划查看方法EXPLAIN,同时提出性能优化技巧如合理使用索引、避免SELECT*、JOIN... 目录1. SQL语句的基本结构2. SQL语句的执行过程3. SQL语句的执行计划4. 常见的性能优

Java获取当前时间String类型和Date类型方式

《Java获取当前时间String类型和Date类型方式》:本文主要介绍Java获取当前时间String类型和Date类型方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,... 目录Java获取当前时间String和Date类型String类型和Date类型输出结果总结Java获取

Python实现批量提取BLF文件时间戳

《Python实现批量提取BLF文件时间戳》BLF(BinaryLoggingFormat)作为Vector公司推出的CAN总线数据记录格式,被广泛用于存储车辆通信数据,本文将使用Python轻松提取... 目录一、为什么需要批量处理 BLF 文件二、核心代码解析:从文件遍历到数据导出1. 环境准备与依赖库

一文解密Python进行监控进程的黑科技

《一文解密Python进行监控进程的黑科技》在计算机系统管理和应用性能优化中,监控进程的CPU、内存和IO使用率是非常重要的任务,下面我们就来讲讲如何Python写一个简单使用的监控进程的工具吧... 目录准备工作监控CPU使用率监控内存使用率监控IO使用率小工具代码整合在计算机系统管理和应用性能优化中,监

go中的时间处理过程

《go中的时间处理过程》:本文主要介绍go中的时间处理过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1 获取当前时间2 获取当前时间戳3 获取当前时间的字符串格式4 相互转化4.1 时间戳转时间字符串 (int64 > string)4.2 时间字符串转时间