news 2026/2/16 21:12:39

华为OD机考 双机位B/C卷 - 压缩日志查询 (C++ Python JAVA JS C)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
华为OD机考 双机位B/C卷 - 压缩日志查询 (C++ Python JAVA JS C)

题目描述

某设备需要记录每分钟检测到的指标值。为了节约存储空间,将连续相同指标值的记录合并。

压缩之前: 202411231000,11 202411231001,11 202411231002,12 202411231003,12 202411231004,10 202411231005,17 202411231006,17 202411231007,17

压缩之后: 202411231000,202411231001,11 202411231002,202411231003,12 202411231004,202411231004,10 202411231005,202411231007,17

查询时,根据输入的时间范围进行查询,需要返回回时间范围内记录的每分钟的指标值,如果某个时间点没有记录值,则此条记录忽略不返回。

输入描述

第一行为查询的时间范围,格式是:startTime,endTime。查询的时间范围为闭区间,即大于等于startTime且小于等于endTime, startTime <= endTime,且他们跨度的分钟数小于100;

第二行为压缩日志记录的行数,100 >= N > 0;

第三行及以后为压缩日志内容。每一行的格式为:startTime,endTime,kpi,其中 startTime<=endTime,10^5>kpi>=0;记录已按升序进行排序。

不保证两行记录之间是紧密连接,startTime和endTime的时间跨度可能很大。 如:上一行的数据显示范围是202411231540, 202411231542,下一行的数据显示可以是 202411231544, 202411231547, 中间202411231543的数据可能由于其他原因缺失。

输出描述

输出描述 查询到的日志清单,如: 202411231010,11 202411231011,10 202411231012,10 202411231013,16

输出结果按数据时间升序排序。

补充说明 输入的数据可能超出当前已存储的数据范围,此时只输出查询到的数据。 如果从头到尾都没有查询到记录,则输出-1。

用例1

输入

202411231010,202411231013

4

202411231000,202411231010,11

202411231011,202411231012,10

202411231013,202411231020,16

202411231021,202411231028,17

输出

202411231010,11

202411231011,10

202411231012,10

202411231013,16

说明

202411231010时间的指标值在202411231000,202411231010范围内,值是11 202411231011,202411231012时间的指标值在202411231011,202411231012范围内,值是10 202411231013时间的指标值在202411231013,202411231020范围内,值是16

问题分析

题目要求处理压缩后的时间序列数据,并根据查询范围恢复每分钟的原始数据。压缩数据格式为startTime,endTime,value,表示从startTimeendTime(闭区间)每分钟的指标值均为value。查询时需要将压缩数据解压为每分钟的记录,并筛选出落在查询时间范围内的记录。

解决思路

  1. 解析查询范围:获取查询的起始时间和结束时间。
  2. 处理压缩数据:遍历每条压缩记录,检查其时间范围是否与查询范围有交集。
  3. 生成每分钟记录:对于有交集的压缩记录,生成每分钟的记录,并筛选出落在查询范围内的记录。
  4. 合并和排序结果:将所有符合条件的记录按时间升序排序后输出。

代码实现

C++
#include <iostream> #include <vector> #include <algorithm> using namespace std; struct Record { long long time; int value; }; bool compareRecords(const Record &a, const Record &b) { return a.time < b.time; } int main() { long long startQuery, endQuery; char comma; cin >> startQuery >> comma >> endQuery; int n; cin >> n; vector<Record> records; for (int i = 0; i < n; ++i) { long long start, end; int value; cin >> start >> comma >> end >> comma >> value; long long overlapStart = max(start, startQuery); long long overlapEnd = min(end, endQuery); if (overlapStart <= overlapEnd) { for (long long t = overlapStart; t <= overlapEnd; ++t) { records.push_back({t, value}); } } } if (records.empty()) { cout << -1 << endl; } else { sort(records.begin(), records.end(), compareRecords); for (const auto &record : records) { cout << record.time << "," << record.value << endl; } } return 0; }
C
#include <stdio.h> #include <stdlib.h> typedef struct { long long time; int value; } Record; int compareRecords(const void *a, const void *b) { Record *ra = (Record *)a; Record *rb = (Record *)b; return (ra->time > rb->time) - (ra->time < rb->time); } int main() { long long startQuery, endQuery; scanf("%lld,%lld", &startQuery, &endQuery); int n; scanf("%d", &n); Record *records = malloc(100 * sizeof(Record)); int count = 0; for (int i = 0; i < n; ++i) { long long start, end; int value; scanf("%lld,%lld,%d", &start, &end, &value); long long overlapStart = start > startQuery ? start : startQuery; long long overlapEnd = end < endQuery ? end : endQuery; if (overlapStart <= overlapEnd) { for (long long t = overlapStart; t <= overlapEnd; ++t) { records[count].time = t; records[count].value = value; count++; } } } if (count == 0) { printf("-1\n"); } else { qsort(records, count, sizeof(Record), compareRecords); for (int i = 0; i < count; ++i) { printf("%lld,%d\n", records[i].time, records[i].value); } } free(records); return 0; }
Python
start_query, end_query = map(int, input().split(',')) n = int(input()) records = [] for _ in range(n): start, end, value = map(int, input().split(',')) overlap_start = max(start, start_query) overlap_end = min(end, end_query) if overlap_start <= overlap_end: for t in range(overlap_start, overlap_end + 1): records.append((t, value)) if not records: print(-1) else: records.sort() for t, value in records: print(f"{t},{value}")
Java
import java.util.*; public class Main { public static void main(String[] args) { Scanner scanner = new Scanner(System.in); String[] queryRange = scanner.nextLine().split(","); long startQuery = Long.parseLong(queryRange[0]); long endQuery = Long.parseLong(queryRange[1]); int n = Integer.parseInt(scanner.nextLine()); List<Record> records = new ArrayList<>(); for (int i = 0; i < n; i++) { String[] parts = scanner.nextLine().split(","); long start = Long.parseLong(parts[0]); long end = Long.parseLong(parts[1]); int value = Integer.parseInt(parts[2]); long overlapStart = Math.max(start, startQuery); long overlapEnd = Math.min(end, endQuery); if (overlapStart <= overlapEnd) { for (long t = overlapStart; t <= overlapEnd; t++) { records.add(new Record(t, value)); } } } if (records.isEmpty()) { System.out.println(-1); } else { records.sort(Comparator.comparingLong(Record::getTime)); for (Record record : records) { System.out.println(record.getTime() + "," + record.getValue()); } } } static class Record { private long time; private int value; public Record(long time, int value) { this.time = time; this.value = value; } public long getTime() { return time; } public int getValue() { return value; } } }
JavaScript
const readline = require('readline'); const rl = readline.createInterface({ input: process.stdin, output: process.stdout }); let lines = []; rl.on('line', (line) => { lines.push(line); }).on('close', () => { const [startQuery, endQuery] = lines[0].split(',').map(Number); const n = parseInt(lines[1]); let records = []; for (let i = 2; i < 2 + n; i++) { const [start, end, value] = lines[i].split(',').map(Number); const overlapStart = Math.max(start, startQuery); const overlapEnd = Math.min(end, endQuery); if (overlapStart <= overlapEnd) { for (let t = overlapStart; t <= overlapEnd; t++) { records.push({ time: t, value: value }); } } } if (records.length === 0) { console.log(-1); } else { records.sort((a, b) => a.time - b.time); for (const record of records) { console.log(`${record.time},${record.value}`); } } });

代码解释

  • 输入处理:读取查询范围和压缩数据行数,然后逐行读取压缩数据。
  • 时间范围交集计算:对于每条压缩数据,计算其与查询范围的重叠部分。
  • 记录生成:在重叠时间范围内生成每分钟的记录,并存储到列表中。
  • 结果输出:如果列表为空,输出-1;否则对记录按时间排序后逐条输出。

每种语言的实现逻辑相同,只是语法和数据结构略有差异。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/2/7 3:29:09

28、利用 OpenSSH 实现安全远程登录

利用 OpenSSH 实现安全远程登录 在管理基于 UNIX 的系统(如运行 Red Hat Enterprise Linux 的系统)时,OpenSSH 等 SSH 工具至关重要。本文将详细介绍如何从 Red Hat Enterprise Linux 系统连接到 SSH 服务器,以及相关工具的使用方法。 1. 连接 SSH 服务器的准备工作 要连…

作者头像 李华
网站建设 2026/2/12 22:33:02

PaddlePaddle图像分类实战:利用git安装第三方工具链支持

PaddlePaddle图像分类实战&#xff1a;利用git安装第三方工具链支持 在智能制造、质检自动化和智慧零售等场景中&#xff0c;图像分类技术正从实验室走向产线。面对日益复杂的模型结构与部署需求&#xff0c;开发者不再满足于“从零写起”的低效模式——如何快速搭建一个稳定、…

作者头像 李华
网站建设 2026/2/9 23:47:19

Redis远程字典服务

RedisRedis&#xff08;全称&#xff1a;Remote Dictionary Server 远程字典服务&#xff09; 开源的非关系数据库(NoSQL)&#xff0c;使用Key-Value键值对来存储数据&#xff1b; 主要功能&#xff1a;作为缓存&#xff0c;替MySQL抗高并发&#xff1b;Redis为什么快&#xff…

作者头像 李华
网站建设 2026/2/16 1:35:30

Amaze File Manager云存储完整配置指南:一键连接Google Drive等主流服务

想要在Android设备上统一管理所有云存储账户&#xff1f;Amaze File Manager的云服务集成功能让你轻松连接Google Drive、Dropbox、OneDrive等主流云平台&#xff0c;实现跨平台文件一站式管理。本指南将详细介绍如何快速配置和使用这些强大的云存储功能。&#x1f680; 【免费…

作者头像 李华
网站建设 2026/2/10 5:31:47

2026毕设ssm+vue基于课程群的实验管理平台论文+程序

本系统&#xff08;程序源码&#xff09;带文档lw万字以上 文末可获取一份本项目的java源码和数据库参考。系统程序文件列表开题报告内容一、选题背景近年来&#xff0c;随着互联网技术的迅猛发展&#xff0c;动漫文化在全球范围内迅速传播&#xff0c;尤其在年轻群体中拥有广泛…

作者头像 李华
网站建设 2026/2/5 6:32:56

2026毕设ssm+vue基于鸿蒙操作系统的新闻app设计论文+程序

本系统&#xff08;程序源码&#xff09;带文档lw万字以上 文末可获取一份本项目的java源码和数据库参考。系统程序文件列表开题报告内容一、选题背景随着互联网技术的快速发展&#xff0c;动漫文化在我国青少年群体中影响力日益增强&#xff0c;成为网络内容消费的重要组成部分…

作者头像 李华