4320: ShangHai2006 Homework
4320: ShangHai2006 Homework
分析:
分块。对权值模数进行分块,模数小于$\sqrt V$的($V$为权值上界),暴力处理。
模数大于$\sqrt V$的,设模数是k,枚举k的倍数,然后查询大于[k,2k]之间的最小的数x,这个区间的mod k最小的数就是x-k。k的倍数共有$\sqrt V$个,每次查询,再对权值进行分块,并维护后缀最小值,做到$O(1)$查询。复杂度$O(n \sqrt V)$
代码:
#include<cstdio>
#include<algorithm>
#include<cstring>
#include<iostream>
#include<cmath>
#include<cctype>
#include<set>
#include<queue>
#include<vector>
#include<map>
using namespace std;
typedef long long LL; inline int read() {
int x=,f=;char ch=getchar();for(;!isdigit(ch);ch=getchar())if(ch=='-')f=-;
for(;isdigit(ch);ch=getchar())x=x*+ch-'';return x*f;
} const int N = , M = , INF = 1e9;
int bel[N + ], tag[N + ], f[N + ], pt[N + ]; void add(int x) {
for (int i = ; i <= M; ++i) f[i] = min(f[i], x % i);
tag[bel[x]] = min(tag[bel[x]], x);
pt[x] = min(pt[x], x);
for (int i = x - , lim = (bel[x] - ) * M; i >= lim; --i) pt[i] = min(pt[i], pt[i + ]);
for (int i = bel[x] - ; i; --i) tag[i] = min(tag[i], tag[i + ]);
}
int query(int x) {
return min(pt[x], tag[bel[x] + ]);
}
int Ask(int x) {
if (x <= M) return f[x];
int ans = query() % x;
for (int i = x; i <= N; i += x) {
int t = query(i) - i;
if (t < x) ans = min(ans, t);
}
return ans;
}
int main() {
memset(f, 0x3f, sizeof(f));
memset(tag, 0x3f, sizeof(tag));
memset(pt, 0x3f, sizeof(pt));
int n = read();
for (int i = ; i <= N; ++i) bel[i] = (i - ) / M + ;
char opt[];
for (int i = ; i <= n; ++i) {
scanf("%s", opt); int x = read();
if (opt[] == 'A') add(x);
else printf("%d\n", Ask(x));
}
return ;
}
4320: ShangHai2006 Homework的更多相关文章
- bzoj 4320: ShangHai2006 Homework
		
4320: ShangHai2006 Homework Time Limit: 10 Sec Memory Limit: 128 MB Description 1:在人物集合 S 中加入一个新的程序员 ...
 - BZOJ.4320.[ShangHai2006]Homework(根号分治 分块)
		
BZOJ \(\mathbb{mod}\)一个数\(y\)的最小值,可以考虑枚举剩余系,也就是枚举区间\([0,y),[y,2y),[2y,3y)...\)中的最小值(求后缀最小值也一样)更新答案,复 ...
 - bzoj 4320: ShangHai2006 Homework【分块】
		
按根号300000=m分情况讨论 查询是,当x小于等于m,那么可以暴力记录直接出解:否则,用分块维护区间值,查询的时候以x为步长跳根号m次取最小值即可 还有一种并查集方法,来自https://www. ...
 - 【BZOJ4320】ShangHai2006 Homework 分段+并查集
		
[BZOJ4320]ShangHai2006 Homework Description 1:在人物集合 S 中加入一个新的程序员,其代号为 X,保证 X 在当前集合中不存在. 2:在当前的人 ...
 - 【bzoj4320】【ShangHai2006 Homework】【并查集+离线处理】
		
ShangHai2006 Homework Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 918 Solved: 460[Submit][Statu ...
 - BZOJ4320 : ShangHai2006 Homework
		
取$M=\sqrt{300000}$. 设$g[i]$表示程序员的$\bmod i$最小的值. 若$Y<M$,那么可以在$O(M)$时间内完成对所有$g[i]$的修改,$O(1)$时间内完成查询 ...
 - [BZOJ4320][ShangHai2006]Homework(根号分治+并查集)
		
对于<=sqrt(300000)的询问,对每个模数直接记录结果,每次加入新数时暴力更新每个模数的结果. 对于>sqrt(300000)的询问,枚举倍数,每次查询大于等于这个倍数的最小数是多 ...
 - BZOJ4320 ShangHai2006 Homework(分块+并查集)
		
考虑根号分块.对于<√3e5的模数,每加入一个数就暴力更新最小值:对于>√3e5的模数,由于最多被分成√3e5块,查询时对每一块找最小值,这用一些正常的DS显然可以做到log,但不太跑得过 ...
 - 【bzoj4320】ShangHai2006 Homework
		
若Y小于等于sqrt(300000),暴力,对所有的插入的数都更新mn[i]. 若Y大于sqrt(300000),枚举kY,用并查集维护>=i的第一个数,这样只支持删除操作是O(1),然后倒着枚 ...
 
随机推荐
- npm run dev时报错“events.js:160 throw er; // Unhandled 'error' event”
			
经查,此问题由端口占用导致,node服务器默认端口8080已被其他程序占用,关闭占用端口的程序或者修改node服务器的默认端口即可解决此问题
 - Linux less/more命令详解
			
less 的用法比起 more 更加的有弹性.在 more 的时候,我们并没有办法向前面翻, 只能往后面看,但若使用了 less 时,就可以使用 [pageup] [pagedown] 等按键的功能来 ...
 - 【matlab】 QR分解 求矩阵的特征值
			
"QR_H.m" function [Q,R] = QR_tao(A) %输入矩阵A %输出正交矩阵Q和上三角矩阵R [n,n]=size(A); E = eye(n); X = ...
 - Hadoop HBase概念学习系列之数据模型(七)
			
HBase是一个类似BigTable的分布式数据库, 它是一个稀疏的长期存储的(存在硬盘上).多维度的.排序的映射表.这张表(HBase)的索引是行关键字.列关键字和时间戳. HBase中的数据 ...
 - November 19th 2016 Week 47th Saturday
			
Nature didn't need an operation to be beautiful. It just was. 自然之美无需刻意而为,其本身即为美. Recently I saw seve ...
 - n = 3 , while n , continue
 - FtpWebRequest与FtpWebResponse完成FTP操作
			
WebRequestMethods.Ftp类: 表示可与 FTP 请求一起使用的 FTP 协议方法的类型. AppendFile 表示要用于将文件追加到 FTP 服务器上的现有文件的 FTP ...
 - 使用 FRP 反向代理实现 Windows 远程连接
			
互联网普及率的日渐攀升与 IPv4 资源的持续减少,现在大部分家庭宽带都不会分配公网 IP ,这使一些网络应用的实现多了些困难,像个人的 NAS 和一些智能家居设备.对于分配公网 IP ,各地运营商的 ...
 - 打印pdf
			
#include "pdf_print_helper.h" pdf_print_helper::pdf_print_helper(){ } pdf_print_helper::~p ...
 - nodejs11安装教程(升级最新版本)
			
nodejs需要不断升级,那么电脑如何安装nodejs11呢,下面将通过亲身实践来详细介绍 工具/原料 电脑 nodejs11安装包 方法/步骤 访问node11官网,下载安装包,如下 ...