【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

相关文章

MyBatis模糊查询报错:ParserException: not supported.pos 问题解决

《MyBatis模糊查询报错:ParserException:notsupported.pos问题解决》本文主要介绍了MyBatis模糊查询报错:ParserException:notsuppo... 目录问题描述问题根源错误SQL解析逻辑深层原因分析三种解决方案方案一:使用CONCAT函数(推荐)方案二:

MySQL 中的 JSON 查询案例详解

《MySQL中的JSON查询案例详解》:本文主要介绍MySQL的JSON查询的相关知识,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录mysql 的 jsON 路径格式基本结构路径组件详解特殊语法元素实际示例简单路径复杂路径简写操作符注意MySQL 的 J

Go语言开发实现查询IP信息的MCP服务器

《Go语言开发实现查询IP信息的MCP服务器》随着MCP的快速普及和广泛应用,MCP服务器也层出不穷,本文将详细介绍如何在Go语言中使用go-mcp库来开发一个查询IP信息的MCP... 目录前言mcp-ip-geo 服务器目录结构说明查询 IP 信息功能实现工具实现工具管理查询单个 IP 信息工具的实现服

MySQL索引的优化之LIKE模糊查询功能实现

《MySQL索引的优化之LIKE模糊查询功能实现》:本文主要介绍MySQL索引的优化之LIKE模糊查询功能实现,本文通过示例代码给大家介绍的非常详细,感兴趣的朋友一起看看吧... 目录一、前缀匹配优化二、后缀匹配优化三、中间匹配优化四、覆盖索引优化五、减少查询范围六、避免通配符开头七、使用外部搜索引擎八、分

SQL表间关联查询实例详解

《SQL表间关联查询实例详解》本文主要讲解SQL语句中常用的表间关联查询方式,包括:左连接(leftjoin)、右连接(rightjoin)、全连接(fulljoin)、内连接(innerjoin)、... 目录简介样例准备左外连接右外连接全外连接内连接交叉连接自然连接简介本文主要讲解SQL语句中常用的表

MySQL高级查询之JOIN、子查询、窗口函数实际案例

《MySQL高级查询之JOIN、子查询、窗口函数实际案例》:本文主要介绍MySQL高级查询之JOIN、子查询、窗口函数实际案例的相关资料,JOIN用于多表关联查询,子查询用于数据筛选和过滤,窗口函... 目录前言1. JOIN(连接查询)1.1 内连接(INNER JOIN)1.2 左连接(LEFT JOI

MySQL 中查询 VARCHAR 类型 JSON 数据的问题记录

《MySQL中查询VARCHAR类型JSON数据的问题记录》在数据库设计中,有时我们会将JSON数据存储在VARCHAR或TEXT类型字段中,本文将详细介绍如何在MySQL中有效查询存储为V... 目录一、问题背景二、mysql jsON 函数2.1 常用 JSON 函数三、查询示例3.1 基本查询3.2

MySQL中的交叉连接、自然连接和内连接查询详解

《MySQL中的交叉连接、自然连接和内连接查询详解》:本文主要介绍MySQL中的交叉连接、自然连接和内连接查询,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、引入二、交php叉连接(cross join)三、自然连接(naturalandroid join)四

mysql的基础语句和外键查询及其语句详解(推荐)

《mysql的基础语句和外键查询及其语句详解(推荐)》:本文主要介绍mysql的基础语句和外键查询及其语句详解(推荐),本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋... 目录一、mysql 基础语句1. 数据库操作 创建数据库2. 表操作 创建表3. CRUD 操作二、外键

Mybatis 传参与排序模糊查询功能实现

《Mybatis传参与排序模糊查询功能实现》:本文主要介绍Mybatis传参与排序模糊查询功能实现,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录一、#{ }和${ }传参的区别二、排序三、like查询四、数据库连接池五、mysql 开发企业规范一、#{ }和${ }传参的