LOJ #6278 数列分块2题解 2024年第一篇题解

Part #0 . 前言 \text{Part \#0 . 前言} Part #0 . 前言

数列分块1

分块是一种优雅的暴力。


Part #1 . 数列分块入门2 \text{Part \#1 . 数列分块入门2} Part #1 . 数列分块入门2

传送门

观察题目,我们可以发现题目是一个区间查询,区间修改。
首先,题目要求查询的是小于 c 2 c^2 c2 的数的 个数 。 所以可以通过排序之后用 lower_bound 减初始坐标即可。

但是由于是区间修改,所以每一次在修改之后都要对当前所在的块进行一个更新。

代码如下:

inline void update(int x)
{v[x].clear();forz(i,st[x],ed[x]) v[x].push_back(a[i]);sort(v[x].begin(),v[x].end());
}
if(block[l]==block[r])
{forz(i,l,r) a[i]+=c;update(block[l]);
}
else
{forz(i,l,ed[block[l]]) a[i]+=c;update(block[l]);forz(i,block[l]+1,block[r]-1) fk[i]+=c;forz(i,st[block[r]],r) a[i]+=c;update(block[r]);
}

接着来讨论一下区间查询,还是先分两种情况:是否在同一个块内。

  • 如果在同一个块内,可以直接暴力求得答案,复杂度 O ( n ) O(\sqrt{n}) O(n )
  • 如果不在同一个块内,两边非整块的部分暴力,中间用 lower_bound 来求,总复杂度 O ( n + log ⁡ n ) O(\sqrt{n}+\log{n}) O(n +logn)

整一个程序如下,时间复杂度 O ( n n + n log ⁡ n ) O(n\sqrt{n}+n \log n) O(nn +nlogn)

/*
1. sqrt(m*2/3)
*/
#include <bits/stdc++.h>using namespace std;#define int long long
#define fi first
#define se second
#define rg register
#define il inline
#define forz(i,a,b) for(register int i((a));i<=(b);++i)
#define forn(i,a,b) for(register int i((a));i>=(b);--i)
#define IOS ios::sync_with_stdio(0),cin.tie(0),cout.tie(0)inline int read()
{int x=0,f=1;char ch=getchar();while (ch<'0'||ch>'9') {if(ch=='-') f=-1;ch=getchar();}while (ch>='0'&&ch<='9') {x=(x<<3)+(x<<1)+ch-'0';ch=getchar();}return x*f;
}inline void write(int x)
{if(x<0){putchar('-');x=-x;}if(x>9) write(x/10);putchar(x%10+'0');
}const int maxn=5e4+100;
const int mod=993244853;
const int inf=9e18;int a[maxn];
int fk[maxn];
int st[maxn],ed[maxn],lenn[maxn];
int block[maxn];
int num,len;
vector<int> v[maxn];inline void init(int n)
{len=sqrt(n);num=n%len?n/len+1:n/len;forz(i,1,num){st[i]=(i-1)*len+1;ed[i]=min(n,i*len);lenn[i]=ed[i]-st[i]+1;}forz(i,1,num) forz(j,st[i],ed[i]) block[j]=i;
}inline void update(int x)
{v[x].clear();forz(i,st[x],ed[x]) v[x].push_back(a[i]);sort(v[x].begin(),v[x].end());
}inline void solve()
{int n=read();init(n);forz(i,1,n){a[i]=read();v[block[i]].push_back(a[i]);}forz(i,1,num) sort(v[i].begin(),v[i].end());while (n--){int op=read(),l=read(),r=read(),c=read();if(!op){if(block[l]==block[r]){forz(i,l,r) a[i]+=c;update(block[l]);}else{forz(i,l,ed[block[l]]) a[i]+=c;update(block[l]);forz(i,block[l]+1,block[r]-1) fk[i]+=c;forz(i,st[block[r]],r) a[i]+=c;update(block[r]);}}else{int cnt=0;if(block[l]==block[r]){forz(i,l,r) if(a[i]+fk[block[i]]<c*c) cnt++;}else{forz(i,l,ed[block[l]]) if(a[i]+fk[block[i]]<c*c) cnt++;forz(i,block[l]+1,block[r]-1){int ans=c*c-fk[i];                     cnt+=lower_bound(v[i].begin(),v[i].end(),ans)-v[i].begin();}forz(i,st[block[r]],r) if(a[i]+fk[block[i]]<c*c) cnt++;}write(cnt);putchar('\n');}}            putchar('\n'); 
}signed main()
{
//    IOS;int _=1;while (_--) solve();return 0;
}

已经2024年了,祝大家在2024年一帆风顺,前途似锦,期末取得佳绩。

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

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

相关文章

数据结构式新年贺词

冒泡排序&#xff0c;选择排序&#xff0c;插入排序&#xff0c;快速排序&#xff0c;堆排序&#xff0c;归并排序&#xff0c;希尔排序&#xff0c;桶排序&#xff0c;基数排序新年帮您排忧解难。 有向图&#xff0c;无向图&#xff0c;有环图&#xff0c;无环图&#xff0c;…

汽车保养软件app开发步骤

“增强您的动力&#xff0c;为您的旅程加油——每一刻都讲述着关爱的故事。构建汽车维护软件app&#xff0c;为您的车辆提供数字化的维修站&#xff0c;从而开启长寿之路。智能驾驶、互联驾驶、自信驾驶。” 疯狂地搜索旧收据并猜测上次换油时间的日子已经一去不复返了。如果您…

51单片机点灯入门教程——2. 呼吸灯效果

基本说明 本章使用芯片&#xff1a;STC8H8K64U核心板 芯片手册&#xff1a;点此查看 Keil 开发环境配置&#xff1a;点此查看 本章学习内容&#xff1a;利用库函数&#xff0c;开发C程序&#xff0c;实现呼吸灯效果。 代码实例 需求&#xff1a;使用串口来控制呼吸灯效果&…

ElasticSearch Nested类型全文检索、聚合查询

ElasticSearch Nested类型全文检索、聚合查询 Nested类型全文检索 创建索引 PUT /products1 {"mappings": {"properties": {"fulltext": {"type": "text"},"name": {"type": "text","…

JavaScript 基础通关

快速熟悉 JavaScript 的基础语法&#xff0c;比较高级的比如事件放在后面的笔记中。 JavaScript 1. JavaScript 介绍 1.1 JavaScript 基本介绍 JavaScript 是一门运行在客户端&#xff08;浏览器&#xff09;的编程语言&#xff0c;实现人机交互的效果。实现网页特效、表单验…

Python入门学习篇(十四)——模块文件操作

1 模块 1.1 理解 包: python中带有__init__.py文件的文件夹 模块: 文件名(不包含.py后缀),如python官方的time.py中time就是模块1.2 示例代码 import datetime# 调用datetime模块中的datetime类的now()方法 t datetime.datetime.now() # 格式化输出日期和时间 strftime(&qu…

基于BP神经网络的磨具变形量分析,BP神经网络详细原理

目录 摘要 BP神经网络参数设置及各种函数选择 参数设置 训练函数 传递函数 学习函数 性能函数 显示函数 前向网络创建函数 BP神经网络训练窗口详解 训练窗口例样 训练窗口四部详解 基于BP神经网络的磨具变形量分析 完整代码下载链接:基于BP神经网络的磨具变形量分析(代码完整…

Vue2中使用echarts,并从后端获取数据同步

一、安装echarts npm install echarts -S 二、导入echarts 在script中导入&#xff0c;比如&#xff1a; import * as echarts from "echarts"; 三、查找要用的示例 比如柱状图 四、初始化并挂载 <template><div id"total-orders-chart" s…

开发Python网络爬虫应用,爬取链家新房楼盘信息保存到mongodb中,并分析相关数据

这里写自定义目录标题 爬取代码分析数据问题 爬取代码 import requests import time from lxml import html from pymongo import MongoClient import randomBASEURL https://cq.fang.lianjia.com/loupan/# 获取某市区域的所有链接 def get_areas(url):print(获取区县列表)# …

git解决冲突场景

文章目录 git解决冲突场景 git解决冲突场景 假设我们在公司开发了一个功能修改了一个文件 我们现在模拟修改文件之后提交一个版本到本地&#xff0c;但是不上传到远程仓库 假设我们现在回到家开发代码&#xff0c;需要拉去最新的代码 提示已经更新。根本没有最新的代码改动&am…

[EFI]HP Spectre 13 v102nl电脑 Hackintosh 黑苹果efi引导文件

硬件型号驱动情况主板 HP Spectre 13 v102nl 处理器Intel Core i7-7500U (7th gen - Kaby Lake)已驱动内存8 GB LPDDR3-1866 SDRAM已驱动硬盘512 GB Toshiba NVMe™ M.2 SSD已驱动显卡Intel HD Graphics 620已驱动声卡Conexant CX8200 (0x2008)已驱动网卡I1211 Gigabit Etherne…

java基础知识点,封装,继承,多态,instanceof 重点笔记

封装 面向对象的三大核心思想: 封装、继承、多态 1&#xff1a;概念 使一种屏障, 防止对象属性被外界任意访问,提高对象属性的安全性 步骤 属性私有化 private 数据类型 属性名; 访问修饰符含义作用范围public公共的,公开的任意位置都可访问private私有的只有本类内部可以访问…

Codeforces Round 917 (Div. 2) A~F

A.Least Product(思维) 题意&#xff1a; 给出一个数组 a 1 , a 2 , . . . , a n a_1, a_2, ..., a_n a1​,a2​,...,an​&#xff0c;你可以进行若干次以下操作&#xff1a; 选择数组中的一个元素 a i a_i ai​&#xff0c;将这个数字修改为 0 ∼ a i 0 \sim a_i 0∼ai​之…

spingboot整合Swagger教程

spingboot整合Swagger教程 大家好&#xff0c;我是免费搭建查券返利机器人赚佣金就用微赚淘客系统3.0的小编&#xff0c;也是冬天不穿秋裤&#xff0c;天冷也要风度的程序猿&#xff01;今天&#xff0c;我将和大家分享一项对于Java后端开发极为重要的技术——“Spring Boot整…

PHP与Angular详细对比 帮助你选择合适的项目技术

开发可有效扩展并提供诺克斯堡级安全性的Web应用程序和网站是每个开发人员的梦想。而使用这样的产品是每个用户的愿望。因此&#xff0c;为您的项目选择最合适和可靠的技术非常关键。 虽然PHP和Angular是完全不同的技术——PHP与JavaScript是一个更恰当的比较——但它们都广泛…

基于SpringBoot的图书商城管理系统

文章目录 项目介绍主要功能截图:部分代码展示设计总结项目获取方式🍅 作者主页:超级无敌暴龙战士塔塔开 🍅 简介:Java领域优质创作者🏆、 简历模板、学习资料、面试题库【关注我,都给你】 🍅文末获取源码联系🍅 项目介绍 基于SpringBoot的图书商城管理系统,java…

ACES 增强版不丹水稻作物地图(2016-2022 年)

ACES 增强版不丹水稻作物地图&#xff08;2016-2022 年&#xff09; 用于改善粮食安全决策的 2016-2022 年年度作物类型稻米地图仍然是不丹的一项挑战。这些地图是与不丹农业部和 SERVIR 合作开发的。通过专注于发展不丹的科学、技术、工程和数学 (STEM)&#xff0c;我们共同开…

kotlin快速入门1

在Google I/O 2017中&#xff0c;Google 宣布 Kotlin 成为 Android 官方开发语言。目前主流AndroidApp开发已经全部切换成此语言&#xff0c;因此对于Android开发而言&#xff0c;掌握Kotlin已经变成必要事情。 Kotlin 是一种在 Java 虚拟机上运行的静态类型编程语言&#xff…

LeetCode第20题 - 有效的括号

题目 给定一个只包括 ‘(’&#xff0c;‘)’&#xff0c;‘{’&#xff0c;‘}’&#xff0c;‘[’&#xff0c;‘]’ 的字符串&#xff0c;判断字符串是否有效。 有效字符串需满足&#xff1a; 左括号必须用相同类型的右括号闭合。左括号必须以正确的顺序闭合。 注意空字符串…

面试题: 你是如何做好Unity项目性能优化的

在面试中&#xff0c;我们经常会被问各种”莫名奇妙”的问题, 比如这道:”你是如何做好Unity项目性能优化的?”。“这个问题也太泛了吧&#xff0c;没有具体的优化点,这怎么回答?” 瞬间跃入脑海。做面试复盘的时候&#xff0c;你可能会想这个面试官是不是什么都不懂&#xf…