算法日记11:SC63(离散化)

一、题目

在这里插入图片描述

二、题解

法一:前缀和(会炸)

  • 对于这道题目,我们的第一个朴素想法就是用前缀和来进行简化操作,这个思路非常简单,就是前缀和的标准模板题,代码如下
void solve()
{int n,q;cin>>n>>q;while(n--){int i,x;cin>>i>>x;a[i]+=x;}//前缀和for(int i=1;i<=n;i++) a[i]+=a[i-1];while(q--){int l,r;cin>>l>>r;cout<<a[r]-a[l-1]<<'\n';}
}

法二:离散化

1、通过观察我们可以发现:数组的下标范围(1e9)>>操作数据点访问(n+2q==3e5),也就是会造成大量下标浪费,因此我们可以想到把数据进行离散化

在这里插入图片描述

2、先对数据离线操作(先把操作存储起来,在进行了某些步骤之后再进行操作)

在这里插入图片描述

2.1具体步骤如下:(目的在于找出我们到底需要访问哪些点,并且把对原始点的操作–>对离散点的操作

在这里插入图片描述

3、对样例操作如下:

3.1:找出需要操作的点

在这里插入图片描述

	int n,q;cin>>n>>q;for(int j=1;j<=n;j++)  //输入操作{int i,x;cin>>i>>x;X.push_back(i); //存入X用来查看有效点add[j]={i,x};   //存储操作点/值}for(int j=1;j<=q;j++)   //输入询问{int l,r;cin>>l>>r;X.push_back(l); //存入X用来查看有效点X.push_back(r);que[j]={l,r};}//排序去重sort(X.begin(),X.end());X.erase(unique(X.begin(),X.end()),X.end());
3.2:此时,数据(离散化)变成了:

在这里插入图片描述

3.3:此时把对原操作—>对离散操作(二分),也就是把对原数组数据操作一一映射到对离散数组的操作

在这里插入图片描述在这里插入图片描述

int FindIndex(int x)    //二分找第一个>=x的下标
{return lower_bound(X.begin(),X.end(),x)-X.begin()+1;
}for(int i=1;i<=n;i++)   //add映射到离散数组{int i_=FindIndex(add[i].a); //第i_个元素 + x_int x_=add[i].b;a[i_]+=x_;}for(int i=1;i<=X.size();i++) a[i]+=a[i-1];   //前缀和
3.4:同理,我们也把询问的操作映射到离散数组上,求解完毕!

在这里插入图片描述

for(int i=1;i<=n;i++)   //add映射到离散数组{int i_=FindIndex(add[i].a); //第i_个元素 + x_int x_=add[i].b;a[i_]+=x_;}for(int i=1;i<=X.size();i++) a[i]+=a[i-1];   //前缀和for(int i=1;i<=q;i++)   //que映射到离散数组{int l=FindIndex(que[i].a);int r=FindIndex(que[i].b);cout<<a[r]-a[l-1]<<'\n';}

三、完整代码如下:

#include<bits/stdc++.h>
using namespace std;typedef long long ll;
const int N=3e5+7;
int a[N];	//离散化数组
vector<int>X;   //有效点数组struct Q{  //存储加/询问操作int a;int b;
}add[N],que[N];int FindIndex(int x)    //二分找第一个>=x的下标
{return lower_bound(X.begin(),X.end(),x)-X.begin()+1;
}void solve()
{int n,q;cin>>n>>q;for(int j=1;j<=n;j++)  //输入操作{int i,x;cin>>i>>x;X.push_back(i); //存入X用来查看有效点add[j]={i,x};   //存储操作点/值}for(int j=1;j<=q;j++)   //输入询问{int l,r;cin>>l>>r;X.push_back(l); //存入X用来查看有效点X.push_back(r);que[j]={l,r};}//排序去重sort(X.begin(),X.end());X.erase(unique(X.begin(),X.end()),X.end());for(int i=1;i<=n;i++)   //add映射到离散数组{int i_=FindIndex(add[i].a); //第i_个元素 + x_int x_=add[i].b;a[i_]+=x_;}for(int i=1;i<=X.size();i++) a[i]+=a[i-1];   //前缀和for(int i=1;i<=q;i++)   //que映射到离散数组{int l=FindIndex(que[i].a);int r=FindIndex(que[i].b);cout<<a[r]-a[l-1]<<'\n';}
}int main()
{int _=1;while(_--) solve();return 0;
}

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

w185客户关系管理系统

&#x1f64a;作者简介&#xff1a;多年一线开发工作经验&#xff0c;原创团队&#xff0c;分享技术代码帮助学生学习&#xff0c;独立完成自己的网站项目。 代码可以查看文章末尾⬇️联系方式获取&#xff0c;记得注明来意哦~&#x1f339;赠送计算机毕业设计600个选题excel文…

[STM32 标准库]EXTI应用场景 功能框图 寄存器

一、EXTI 外部中断在嵌入式系统中有广泛的应用场景&#xff0c;如按钮开关控制&#xff0c;传感器触发&#xff0c;通信接口中断等。其原理都差不多&#xff0c;STM32会对外部中断引脚的边沿进行检测&#xff0c;若检测到相应的边沿会触发中断&#xff0c;在中断中做出相应的处…

Windows下怎么安装FFFmpeg呢?

在Windows下使用Open-webui报错&#xff0c;说Couldnt find ffmpeg or avconv,解决open-webui报错Couldn‘t find ffmpeg or avconv-CSDN博客于是尝试解决问题&#xff0c;那么Windows下怎么安装FFFmpeg呢&#xff1f; 尝试了两种方法。 第一种方法pip安装&#xff08;失败&…

Hive on Spark优化

文章目录 第1章集群环境概述1.1 集群配置概述1.2 集群规划概述 第2章 Yarn配置2.1 Yarn配置说明2.2 Yarn配置实操 第3章 Spark配置3.1 Executor配置说明3.1.1 Executor CPU核数配置3.1.2 Executor内存配置3.1.3 Executor个数配置 3.2 Driver配置说明3.3 Spark配置实操 第4章 Hi…

【OMCI实践】ONT上线过程的omci消息(三)

引言 在上一篇文章【OMCI实践】ONT上线过程的omci消息&#xff08;二&#xff09;-CSDN博客中&#xff0c;主要介绍了ONT上线过程的OMCI交互的第一个阶段和第二个阶段omci消息&#xff0c;本篇介绍第二个阶段剩余的OMCI消息涉及到的受管实体&#xff08;ME&#xff09;的属性。…

保姆级教程Docker部署Zookeeper官方镜像

目录 1、安装Docker及可视化工具 2、创建挂载目录 3、运行Zookeeper容器 4、Compose运行Zookeeper容器 5、查看Zookeeper运行状态 6、验证Zookeeper是否正常运行 1、安装Docker及可视化工具 Docker及可视化工具的安装可参考&#xff1a;Ubuntu上安装 Docker及可视化管理…

【数据结构】栈与队列

栈 栈的概念及结构 栈:一种特殊的线性表&#xff0c;其只允许在固定的一端进行插入和删除元素操作。进行数据插入和删除操作的一端称为栈顶&#xff0c;另一端称为栈底。栈中的数据元素遵守后进先出LIFO(Last In First Out)的原则。 压栈:栈的插入操作叫做进栈/压栈/入栈&…

安全实验作业

一 拓扑图 二 要求 1、R4为ISP&#xff0c;其上只能配置IP地址&#xff1b;R4与其他所有直连设备间均使用共有IP 2、R3-R5-R6-R7为MGRE环境&#xff0c;R3为中心站点&#xff1b; 3、整个OSPF环境IP基于172.16.0.0/16划分&#xff1b; 4、所有设备均可访问R4的环回&#x…

e2studio开发RA4M2(6)----GPIO外部中断(IRQ)配置

e2studio开发RA4M2.6--GPIO外部中断&#xff08;IRQ&#xff09;配置 概述视频教学样品申请硬件准备参考程序源码下载新建工程工程模板保存工程路径芯片配置工程模板选择时钟设置SWD调试口设置GPIO口配置按键中断配置中断回调函数主程序 概述 GPIO&#xff08;通用输入/输出&a…

排序算法--快速排序

快速排序是高效的排序算法&#xff0c;平均时间复杂度为 O(nlog⁡n)&#xff0c;适合大规模数据排序。 1.挖坑法 2左右指针法 3.前后指针法 // 交换两个元素的值 void swap(int* a, int* b) {int temp *a;*a *b;*b temp; }// 分区函数&#xff0c;返回分区点的索引 int par…

分享|LLM通过D-E-P-S完成长时间与多步骤的任务

《Describe, Explain, Plan and Select: Interactive Planning with Large Language Models Enables Open-World Multi-Task Agents&#xff1f; 描述、解释、计划和选择&#xff1a;使用大型语言模型进行交互式规划&#xff0c;实现开放世界的多任务代理 问题背景&#xff1a;…

chrome浏览器chromedriver下载

chromedriver 下载地址 https://googlechromelabs.github.io/chrome-for-testing/ 上面的链接有和当前发布的chrome浏览器版本相近的chromedriver 实际使用感受 chrome浏览器会自动更新&#xff0c;可以去下载最新的chromedriver使用&#xff0c;自动化中使用新的chromedr…

swagger使用指引

1.swagger介绍 在前后端分离开发中通常由后端程序员设计接口&#xff0c;完成后需要编写接口文档&#xff0c;最后将文档交给前端工程师&#xff0c;前端工程师参考文档进行开发。 可以通过一些工具快速生成接口文档 &#xff0c;本项目通过Swagger生成接口在线文档 。 什么…

一文速览DeepSeek-R1的本地部署——可联网、可实现本地知识库问答:包括671B满血版和各个蒸馏版的部署

前言 自从deepseek R1发布之后「详见《一文速览DeepSeek R1&#xff1a;如何通过纯RL训练大模型的推理能力以比肩甚至超越OpenAI o1(含Kimi K1.5的解读)》」&#xff0c;deepseek便爆火 爆火以后便应了“人红是非多”那句话&#xff0c;不但遭受各种大规模攻击&#xff0c;即便…

低通滤波算法的数学原理和C语言实现

目录 概述 1 原理介绍 1. 1 基本概念 1.2 一阶RC低通滤波器模型 2 C语言完整实现 2.1 滤波器结构体定义 2.2 初始化函数 2.3 滤波计算函数 3 应用示例 3.1 噪声信号滤波 3.2 输出效果对比 3.3 关键参数选择指南 4 性能优化技巧 4.1 定点数优化 4.2 抗溢出处理 …

自研有限元软件与ANSYS精度对比-Bar3D2Node三维杆单元模型-央视大裤衩实例

目录 1、“央视大裤衩”自研有限元软件求解 1.1、选择单元类型 1.2、导入“央视大裤衩”工程 1.3、节点坐标定义 1.4、单元连接关系、材料定义 1.5、约束定义 1.6、外载定义 1.7、矩阵求解 1.8、变形云图展示 1.9、节点位移 1.10、单元应力 1.11、节点支反力 2、“…

Hot100之堆

我们的PriorityQueue默认为最小堆&#xff0c;堆顶总是为最小 215数组中的第K个最大元素 题目 思路解析 暴力解法&#xff08;不符合时间复杂度&#xff09; 题目要求我们找到「数组排序后的第 k 个最大的元素&#xff0c;而不是第 k 个不同的元素」。「数组排序后的第 k …

FinRobot:一个使用大型语言模型的金融应用开源AI代理平台

“FinRobot: An Open-Source AI Agent Platform for Financial Applications using Large Language Models” 论文地址&#xff1a;https://arxiv.org/pdf/2405.14767 Github地址&#xff1a;https://github.com/AI4Finance-Foundation/FinRobot 摘要 在金融领域与AI社区间&a…

算法题(57):找出字符串中第一个匹配项的下标

审题: 需要我们根据原串与模式串相比较并找到完全匹配时子串的第一个元素索引&#xff0c;若没有则返回-1 思路&#xff1a; 方法一&#xff1a;BF暴力算法 思路很简单&#xff0c;我们用p1表示原串的索引&#xff0c;p2表示模式串索引。遍历原串&#xff0c;每次遍历都匹配一次…

「全网最细 + 实战源码案例」设计模式——策略模式

核心思想 策略模式&#xff08;Strategy Pattern&#xff09;是一种行为型设计模式&#xff0c;用于定义一系列算法或策略&#xff0c;将它们封装成独立的类&#xff0c;并使它们可以相互替换&#xff0c;而不影响客户端的代码&#xff0c;提高代码的可维护性和扩展性。 结构 …