news 2026/6/10 18:35:08

华为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/6/10 10:51:14

缓存集群性能跃迁:从传统轮询到智能路由的架构革命

缓存集群性能跃迁&#xff1a;从传统轮询到智能路由的架构革命 【免费下载链接】memcached memcached development tree 项目地址: https://gitcode.com/gh_mirrors/mem/memcached 当你的Memcached集群扩展到5台以上服务器时&#xff0c;是否注意到缓存命中率从85%骤降到…

作者头像 李华
网站建设 2026/6/10 17:43:03

安全测试公开课来啦!带你掌握安全测试的核心实战技能

在数字化浪潮席卷的今天&#xff0c;一个看似微小的安全漏洞&#xff0c;就可能导致企业数据泄露、业务中断&#xff0c;甚至造成无法挽回的品牌声誉损失。作为开发、测试或运维人员的你&#xff0c;是否也曾感到焦虑&#xff1a; 面对层出不穷的安全事件&#xff0c;不知从何防…

作者头像 李华
网站建设 2026/6/10 17:43:06

信令是什么?为什么 WebRTC 需要信令?

信令是什么?为什么 WebRTC 需要信令? 本文是 WebRTC 系列专栏的第六篇,也是第二部分"信令与会话管理"的开篇。我们将深入探讨信令的概念、作用以及如何设计自己的信令服务器。 目录 什么是信令信令不是 WebRTC 标准的一部分信令传输的内容信令传输方式信令服务器设…

作者头像 李华
网站建设 2026/6/10 10:52:47

2026毕设ssm+vue基于框架的宠物商城平台论文+程序

本系统&#xff08;程序源码&#xff09;带文档lw万字以上 文末可获取一份本项目的java源码和数据库参考。系统程序文件列表开题报告内容一、选题背景 关于动漫垂直社区的研究&#xff0c;现有成果主要以 B 站、A 站等综合视频平台为主&#xff0c;专门针对“动漫图文分享轻社交…

作者头像 李华
网站建设 2026/6/10 4:18:13

7个关键指标:为什么Noria能实现5倍性能飞跃?

7个关键指标&#xff1a;为什么Noria能实现5倍性能飞跃&#xff1f; 【免费下载链接】noria Fast web applications through dynamic, partially-stateful dataflow 项目地址: https://gitcode.com/gh_mirrors/no/noria 在当今数据密集型Web应用环境中&#xff0c;传统数…

作者头像 李华
网站建设 2026/6/10 15:35:12

一手实测 Nano Banana Pro 后,我总结了 8 种全新的超神玩法

AI 技术的进步总是让我们惊叹不已&#xff0c;而 Nano Banana Pro 的出现&#xff0c;无疑是其中最引人注目的突破之一。这款基于深度学习和生成对抗网络&#xff08;GAN&#xff09;技术的绘图工具&#xff0c;以其强大的智能化能力和创新性应用&#xff0c;迅速成为了设计师、…

作者头像 李华