【CSP试题回顾】202112-2-序列查询新解

2024-03-09 06:04

本文主要是介绍【CSP试题回顾】202112-2-序列查询新解,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

CSP-202112-2-序列查询新解

关键点:时间复杂度

本题关键在于它避免暴力枚举法的时间复杂度。暴力枚举法可能会对每一对可能的 f(x)g(x) 组合进行比较,其时间复杂度为 O ( n 2 ) O(n^2) O(n2),这对于大数据集来说是不可行的。

  • 【解决思路】:通过逐步遍历 f(x)g(x) 的值(每次只移动到下一个 f(x)g(x) 值),将时间复杂度降低到了 O ( n ) O(n) O(n)。这种方法只需要遍历一次 f(x)g(x) 的所有值,大大减少了计算量。

  • 这种方法的效率提高主要是因为它保持了 f(x)g(x) 索引的逻辑顺序,这样就能在单个循环内完成所有的计算,避免了不必要的重复比较。

解题思路

1.初始化

  • FiGi 分别是 f(x)g(x) 当前索引的指针,初始值都设置为 0。
  • lastIndex 表示最近处理的点的位置,初始化为 0。
  • error 用于累积总误差,也是从 0 开始的。

2.遍历过程

  1. 循环条件while 循环会持续,直到 FiGi 其中一个超过各自数组的长度。确保所有的 f(x)g(x) 值都被遍历

  2. 找到下一个处理点(重要):循环中,首先确定下一个处理点的位置 nextIndex。这是当前 f(x)(由 arrF_x[Fi] 给出)和 g(x)(由 arrG_x[Gi] 给出)值中较小的一个。这个点是当前关注的位置,因为它表示下一个即将处理的 f(x)g(x) 的值。

  3. 计算长度和误差(重要):根据 nextIndexlastIndex(上一个点的位置),计算这两点之间的距离 length = nextIndex - lastIndex。然后,利用这段长度和 FiGi 之间的差的绝对值更新总误差 error。这个差的绝对值代表在此段中 f(x)g(x) 之间的偏差。

  4. 更新索引(重要):如果 arrF_x[Fi](当前 f(x) 的值)是 nextIndex,那么 Fi 自增以移动到 f(x) 的下一个值。同样,如果 arrG_x[Gi](当前 g(x) 的值)是 nextIndex,那么 Gi 自增以移动到 g(x) 的下一个值。这个步骤确保了在每次迭代后,FiGi 至少有一个向前移动。

  5. 重复过程:更新 lastIndexnextIndex,然后重复循环,直到遍历完所有的 f(x)g(x) 值。

3.逐步遍历的意义

  • 通过逐步遍历,代码能够有效地计算在每一小段上 f(x)g(x) 的近似误差,并累积这些误差以得到整体误差。这种方法利用了线性遍历的策略,减少了计算复杂度,相比暴力方法有显著的性能提升。

完整代码

#include<iostream>
#include<vector>
using namespace std;long long n, N, error, r;int main() {   cin >> n >> N; // 输入n和Nr = N / (n + 1); // 计算每个区间的长度vector<long long> arrF_x(n); // 存储f(x)的值for (int i = 0; i < n; i++) {cin >> arrF_x[i]; // 输入f(x)的值}arrF_x.push_back(N); // 将N作为最后一个f(x)的值,确保能够覆盖全部范围vector<long long> arrG_x; // 存储g(x)的值for (int i = r; i < N; i += r) {arrG_x.push_back(i); // 按照间隔r生成g(x)的值}if (arrG_x.back() != N) { // 确保N也作为g(x)的一个值arrG_x.push_back(N);}long long Fi = 0, Gi = 0, lastIndex = 0; // 初始化索引和上一个点的位置while (Fi < arrF_x.size() && Gi < arrG_x.size()) { // 遍历f(x)和g(x)long long nextIndex = min(arrF_x[Fi], arrG_x[Gi]); // 找到下一个处理点的位置long long length = nextIndex - lastIndex; // 计算两点之间的长度lastIndex = nextIndex; // 更新上一个点的位置error += length * abs(Fi - Gi); // 更新误差if (arrF_x[Fi] == nextIndex) Fi++; // 如果f(x)到达下一个点,则移动Fiif (arrG_x[Gi] == nextIndex) Gi++; // 如果g(x)到达下一个点,则移动Gi}cout << error; // 输出总误差return 0;
}

请添加图片描述

这篇关于【CSP试题回顾】202112-2-序列查询新解的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/789738

相关文章

Python的Darts库实现时间序列预测

《Python的Darts库实现时间序列预测》Darts一个集统计、机器学习与深度学习模型于一体的Python时间序列预测库,本文主要介绍了Python的Darts库实现时间序列预测,感兴趣的可以了解... 目录目录一、什么是 Darts?二、安装与基本配置安装 Darts导入基础模块三、时间序列数据结构与

MyBatis分页查询实战案例完整流程

《MyBatis分页查询实战案例完整流程》MyBatis是一个强大的Java持久层框架,支持自定义SQL和高级映射,本案例以员工工资信息管理为例,详细讲解如何在IDEA中使用MyBatis结合Page... 目录1. MyBATis框架简介2. 分页查询原理与应用场景2.1 分页查询的基本原理2.1.1 分

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

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

Java实现复杂查询优化的7个技巧小结

《Java实现复杂查询优化的7个技巧小结》在Java项目中,复杂查询是开发者面临的“硬骨头”,本文将通过7个实战技巧,结合代码示例和性能对比,手把手教你如何让复杂查询变得优雅,大家可以根据需求进行选择... 目录一、复杂查询的痛点:为何你的代码“又臭又长”1.1冗余变量与中间状态1.2重复查询与性能陷阱1.

MySQL中查询和展示LONGBLOB类型数据的技巧总结

《MySQL中查询和展示LONGBLOB类型数据的技巧总结》在MySQL中LONGBLOB是一种二进制大对象(BLOB)数据类型,用于存储大量的二进制数据,:本文主要介绍MySQL中查询和展示LO... 目录前言1. 查询 LONGBLOB 数据的大小2. 查询并展示 LONGBLOB 数据2.1 转换为十

使用SpringBoot+InfluxDB实现高效数据存储与查询

《使用SpringBoot+InfluxDB实现高效数据存储与查询》InfluxDB是一个开源的时间序列数据库,特别适合处理带有时间戳的监控数据、指标数据等,下面详细介绍如何在SpringBoot项目... 目录1、项目介绍2、 InfluxDB 介绍3、Spring Boot 配置 InfluxDB4、I

Go语言使用Gin处理路由参数和查询参数

《Go语言使用Gin处理路由参数和查询参数》在WebAPI开发中,处理路由参数(PathParameter)和查询参数(QueryParameter)是非常常见的需求,下面我们就来看看Go语言... 目录一、路由参数 vs 查询参数二、Gin 获取路由参数和查询参数三、示例代码四、运行与测试1. 测试编程路

MySQL 数据库表与查询操作实战案例

《MySQL数据库表与查询操作实战案例》本文将通过实际案例,详细介绍MySQL中数据库表的设计、数据插入以及常用的查询操作,帮助初学者快速上手,感兴趣的朋友跟随小编一起看看吧... 目录mysql 数据库表操作与查询实战案例项目一:产品相关数据库设计与创建一、数据库及表结构设计二、数据库与表的创建项目二:员

Linux查询服务器 IP 地址的命令详解

《Linux查询服务器IP地址的命令详解》在服务器管理和网络运维中,快速准确地获取服务器的IP地址是一项基本但至关重要的技能,下面我们来看看Linux中查询服务器IP的相关命令使用吧... 目录一、hostname 命令:简单高效的 IP 查询工具命令详解实际应用技巧注意事项二、ip 命令:新一代网络配置全

Linux查询服务器系统版本号的多种方法

《Linux查询服务器系统版本号的多种方法》在Linux系统管理和维护工作中,了解当前操作系统的版本信息是最基础也是最重要的操作之一,系统版本不仅关系到软件兼容性、安全更新策略,还直接影响到故障排查和... 目录一、引言:系统版本查询的重要性二、基础命令解析:cat /etc/Centos-release详