P9809 [SHOI2006] 作业 Homework 浅显易懂讲解这道题为什么根号分治

news2024/11/27 0:24:43

题目:

我们有一堆数,找出模Y的最小值。

思路:

我们初步思考,会发现每个Y是一段,比如 1~Y , Y~2Y , 2Y~3Y ...

每个区间都可能有最小的答案。

这里对Y可以使用根号分治,因为:

当Y足够大时,每个区间都很大,区间数就很少。

而当Y足够小时,我们可以暴力这部分Y。

当Y足够大时,区间很大,我们对区间做处理:找大于1的最小值,大于Y的最小值,大于2Y的最小值,只需要找几次就能找完。

————

暂时规定Y小于V时,Y足够小。

A操作:

我们每插入一个数,挨着取模1~V并记录对应的最小值。(这里就是暴力,只记录1~V是可以承受的)

这样取模1~V的时候我们直接得到最小值。可以用map存。

(同时插入的数存入一个set中。)

B操作:

当模数小于V时,我们已经存好了,直接得到答案。

当模数大于V时,我们在每个区间找最小值。(因为区间很大,过几个区间可能就没有数了,结束就好了)

根号:

V怎么取呢?这。。

根号分治!

本题 Y ≤ 3e5,取个几百差不多,V*B == 3e5就行。(这个B对应大区间数目,大区间最小是V的时候也要覆盖整个Y,所以有个B)

可以取 : 480*625        近似根号了,因为我们区间长度是整数

代码细节:

可以直接看代码,也可以看这里帮助理解写法:

set存数,lower_bound是下界的意思(参考set::lower_bound - C++ Reference (cplusplus.com))

(可以测试lower_bound,当找的那个下界x不存在时,返回的是第一个比x大的数的迭代器

而up_bound找的就是第一个比x大的数的迭代器。这里我们要找最小的大于等于区间左边的数)

代码:


#define V 480
#define B 625

void solve()
{
	int n;
	cin >> n;
	set<int>s;
	unordered_map<int, int>m;
	for (int i = 1; i <= n; i++)
	{
		char op;
		int val;
		cin >> op >> val;
		if (op == 'A')
		{
			s.insert(val);
			for (int i = 1; i < V; i++)
			{
				if (m.count(i))m[i] = min(m[i], val % i);
				else m[i] = val % i;
			}
		}
		else
		{
			int ans = LLONG_MAX;
			if (val >= V)
			{
				for (int i = 0; i <= B; i++)
				{
					auto it = s.lower_bound(i * val);
					if (it == s.end())
						break;//都比i*val大了
					ans = min(ans, *it - (i * val));
				}
			}
			else
			{
				ans = m[val];
			}
			cout << ans << endl;
		}

	}
}
signed main()
{
	ios::sync_with_stdio(false);
	cin.tie(0);
	cout.tie(0);
	int t = 1;
	//cin >> t;
	while (t--)
	{
		solve();
	}
	return 0;
}

然而。。。:

值域分块可以再优化,我不会。

我导师的讲解:

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

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

相关文章

MySQL原理(一)架构组成之物理文件组成

目录 一、日志文件 1、错误日志 Error Log 1.1、作用&#xff1a; 1.2、开启关闭&#xff1a; 1.3、使用 2、二进制日志 Binary Log & Binary Log Index 2.1、作用&#xff1a; 2.2、开启关闭&#xff1a; 2.3、Binlog还有一些附加选项参数 &#xff08;1&#x…

8.4 Springboot整合Redis 之RedisTemplate方式

文章目录 前言一、Maven依赖二、配置文件application.properties2.1 连接池核心配置说明三、RedisTemplate配置类四、RedisTemplate工具类五、测试前言 上文我们讲解了官方推荐的Jedis方式,本文讲解Springboot通过Spring Data Redis 集成 Redis,主要使用RedisTemplate方式,…

LeetCode 使循环数组所有元素相等的最少秒数

地址&#xff1a;力扣&#xff08;LeetCode&#xff09;官网 - 全球极客挚爱的技术成长平台 难度&#xff1a;中等 题目描述&#xff1a;给你一个下标从 0 开始长度为 n 的数组 nums 。 每一秒&#xff0c;你可以对数组执行以下操作&#xff1a; 对于范围在 [0, n - 1] 内的每…

Java 类的加载流程

一、类的加载 指的是将类的.class 文件中的二进制 数据读入到内存中&#xff0c;将其放在运行时数据区的方法区内&#xff0c;然后在堆区创 建一个 java.lang.Class 对象&#xff0c;用来封装类在方法区内的数据结构。 类从被加载到虚拟机内存中开始&#xff0c;到卸载出内…

Android super.img解包和打包指南(含工具下载lpunpack、lpmake、lpdump)

本文所有命令均需要在linux 上执行 一、解包 1、将Android sparse image格式的super.img转成二进制文件 $ sudo apt install android-sdk-libsparse-utils $ simg2img super.img super.img.bin 2、下载工具lpunpack 和lpmake、lpdump 以及其依赖库 下载地址:https://downl…

进程控制(二)进程等待

文章目录 进程等待什么是进程等待&#xff1f;&#xff1f;&#xff1f;为什么要进行进程等待&#xff1f;&#xff1f;&#xff1f; 进程等待的方法wait函数waitpid函数 进程等待 什么是进程等待&#xff1f;&#xff1f;&#xff1f; 进程等待是通过wait/waitpid的方式&…

异或运算实现加密解密

异或运算符^&#xff0c;相同为0&#xff0c;不同为1&#xff08;同0非1&#xff09; 由异或运算法则可知&#xff1a;a ^ a 0&#xff0c;a ^ 0 a 如果c a ^ b&#xff0c;那么a b ^ c&#xff0c;即a ^ b ^ b a&#xff0c;^ 的逆运算仍然是 ^ 利用异或运算的性质&am…

python封装的.exe文件是如何在cmd中获取.xml路径的?

这段日子搞项目算法封装&#xff0c;愁死我。来回改了三遍&#xff0c;总算把相对路径、绝对路径&#xff0c;还有cmd给.exe传参的方式搞懂了。 主要是这个语句 workspace sys.argv[1] sys.argv[]的作用就是,在运行python文件的时候从外部输入参数往文件里面传递参数。 外部就…

09. 配置Eth-Trunk

文章目录 一. 初识Eth-Trunk1.1. Eth-Trunk的概述1.2. Eth-Trunk的优势1.3. Eth-Trunk的模式的优势 二. 实验专题2.1. 实验1&#xff1a;手工模式2.1.1. 实验拓扑图2.1.2. 实验步骤&#xff08;1&#xff09;配置PC机的IP地址&#xff08;2&#xff09;在交换机接口划入VLAN&am…

oracle 21C RAC+linux 8安装配置手册

本文详细介绍利用虚拟机安装配置oracle 21c rac OS版本&#xff1a;oracle linux 8.4 oracle版本&#xff1a;21.3 博主文章目前只发布在两个平台CSDN和墨天伦 ID&#xff1a;潇湘秦&#xff0c;转载请注明出处 安装oracle linux 8.4 选择本地可用的ISO 文件&#xff08;虚拟…

AI Prompt工程师 学习整理

前言 如果说Al大语言模型(LLM,Large Language Model)是宝藏我,那么Prompt提示词就是打开宝藏的钥匙。 最新一代的Al大语言模型具备出色的创作能力,能够生成富有人类感情、严谨逻辑、多场景应用的内容,而如何获得高质量的回答,正确学习使用Prompt提示词是关键。 &#x1f4a5…

vue-cli项目运行流程介绍

一、前言 ​ 本文介绍 vue-cli搭建的项目运行流程&#xff0c;基于已经搭建好的基础项目。关于 vue-cli 构建项目的详细流程&#xff0c;可参考博文&#xff1a;使用vue脚手架构建项目 二、main.js 项目运行 会加载入口文件 main.js /* html文件中&#xff0c;通过script …

MYSQL基础(一) --- 学习笔记

一.基础操作 启动与关闭&#xff1a;net start mysql80&#xff0c;net stop mysql80 客户端连接&#xff1a;mysql -u root -p 关系型数据库&#xff1a;建立在关系模型基础上&#xff0c;由多张相互连接的二维表&#xff08;由行和列组成的表&#xff09;组成的数据库 二…

《Pandas 简易速速上手小册》第6章:Pandas 时间序列分析(2024 最新版)

文章目录 6.1 时间序列数据基础6.1.1 基础知识6.1.2 重点案例&#xff1a;股票市场分析6.1.3 拓展案例一&#xff1a;温度变化分析6.1.4 拓展案例二&#xff1a;电商平台日销售额分析 6.2 日期与时间功能6.2.1 基础知识6.2.2 重点案例&#xff1a;活动日志分析6.2.3 拓展案例一…

最全整理!37 个 Python Web 开发框架总结!

大家好&#xff0c;用了 2 周的时间整理了 Python 中所有的网站开发库&#xff08;下文简称&#xff1a;Web 框架&#xff09;&#xff0c;供大家学习参考。 Q&#xff1a;Web 框架到底是什么&#xff1f; A&#xff1a;Web 框架主要用于网站开发。开发者在基于 Web 框架实现…

【数据结构(C语言)】树、二叉树详解

目录 文章目录 前言 一、树的概念及结构 1.1 树的概念 1.2 树的相关概念 1.3 树的表示 1.4 树在实际中的运用 二、二叉树的概念及结构 2.1 二叉树的概念 2.2 二叉树的基本形态 ​编辑2.3 特殊的二叉树 2.4 二叉树的性质 2.5 二叉树的存储结构 三、二叉树的顺序结…

Java编程练习之类的封装2

1.封装一个股票&#xff08;Stock&#xff09;类&#xff0c;大盘名称为上证A股&#xff0c;前一日的收盘点是2844.70点&#xff0c;设置新的当前值如2910.02点&#xff0c;控制台既要显示以上信息&#xff0c;又要显示涨跌幅度以及点数变化的百分比。运行效果如下&#xff1a;…

SketchBook 2022下载安装教程,保姆级教程,操作简单,小白也能轻松搞定,附安装包和工具

前言 Autodesk SketchBook是一款新一代的自然画图软件&#xff0c;软件界面新颖动人&#xff0c;功能强大&#xff0c;仿手绘效果逼真&#xff0c;笔刷工具分为铅笔&#xff0c;毛笔&#xff0c;马克笔&#xff0c;制图笔&#xff0c;水彩笔&#xff0c;油画笔&#xff0c;喷枪…

Offer必备算法_前缀和_牛客+力扣OJ题详解(由易到难)

目录 前缀和算法介绍 一维前缀和 二维前缀和 ①牛客DP34 【模板】前缀和 解析代码 ②牛客DP35 【模板】二维前缀和 解析代码 ③力扣724. 寻找数组的中心下标 解析代码 ④力扣238. 除自身以外数组的乘积 解析代码 ⑤力扣560. 和为 K 的子数组 解析代码 ⑥力扣974. …

2024美国大学生数学建模竞赛A-F题完整思路+配套代码数据+后续高质量参考论文更新

The Mathematical Contest in Modeling (MCM) The Interdisciplinary Contest in Modeling (ICM) 24美赛【完整每问手把手详细思路可修改50页多种思路版本word版保奖论文】配套升级求解代码可视化图表 美赛A-F题完整版获取见文末 下文包含&#xff1a;2024美国大学生数学建模…