4320: ShangHai2006 Homework

Time Limit: 10 Sec Memory Limit: 128 MB

Description

1:在人物集合 S 中加入一个新的程序员,其代号为 X,保证 X 在当前集合中不存在。

2:在当前的人物集合中询问程序员的mod Y 最小的值。 (为什么统计这个?因为拯救

过世界的人太多了,只能取模)

Input

第一行为用空格隔开的一个个正整数 N。

接下来有 N 行,若该行第一个字符为“A” ,则表示操作 1;若为“B”,表示操作 2;

其中 对于 100%的数据:N≤100000, 1≤X,Y≤300000,保证第二行为操作 1。

Output

对于操作 2,每行输出一个合法答案。

Sample Input

5

A 3

A 5

B 6

A 9

B 4

Sample Output

3

1

HINT

【样例说明】

在第三行的操作前,集合里有 3、5 两个代号,此时 mod 6 最小的值是 3 mod 6 = 3;

在第五行的操作前,集合里有 3、5、9,此时 mod 4 最小的值是 5 mod 4 = 1;

题目分析

首先,当\(Y \le \sqrt {MaxY}\),我们可以暴力更新\(ans\)数组。当\(Y \gt \sqrt {MaxY}\)时,我们可以按倍数进行枚举。这样我们就可以保证每次查询都在\(O(\sqrt Y)\)以内。

不过我们在枚举大的\(Y\)时,还要能迅速求出答案,显然我们需要找到\(\le k*Y\)的最小数,显然可以用set水过。

#include <set>
#include <cstdio>
#include <cstring>
using namespace std;
set<int>s;
set<int>::iterator it;
int ans[550];
int main() {
int i,j,n,a,t,res; char op[3];
for(scanf("%d",&n),memset(ans,127,sizeof ans),i=0;i<n;++i) {
scanf("%s%d",op,&a);
if(*op=='A') {
for(j=1;j<550;++j) (t=a%j)<ans[j]?ans[j]=t:1;
s.insert(a);
} else
if(a<550) printf("%d\n",ans[a]);
else { for(j=0,res=0x7f7f7f7f;j<300001;j+=a) {
it=s.lower_bound(j);
if(it==s.end()) continue;
t=*it%a,t<res?res=t:1;
}
printf("%d\n",res);
}
}
return 0;
}

不过,我们也可以用并查集来求出这个数,而且速度更快。

#include <cstdio>
#include <cstring>
#define M 300005
#define N 100005
int fa[M],ans[N],val[N],d[550];
char op[N],ts[4],mark[M];
int find(int u) {return (fa[u]^u)?(fa[u]=find(fa[u])):u;}
void Union(int x,int y) {
x=find(x),y=find(y);
(x<y)?fa[x]=y:fa[y]=x;
}
int main() {
int n,i,j,t; memset(d,127,sizeof d);
for(scanf("%d",&n),i=1;i<=n;++i) {
scanf("%s%d",ts,val+i);
if((op[i]=*ts)=='A') {
for(j=1;j<550;++j) ((t=val[i]%j)<d[j])?d[j]=t:1;
mark[val[i]]=1;
} else ans[i]=d[val[i]];
}fa[300001]=300001;
for(i=300000;i;--i) (mark[i])?fa[i]=i:fa[i]=find(fa[i+1]);
for(i=n;i;--i) {
if(op[i]=='A') Union(val[i],val[i]+1);
else if(val[i]>=550) {
t=find(1),ans[i]=(t==300001)?val[i]-1:(t%val[i]);
for(j=val[i];j<300001;j+=val[i])
(((t=find(j))==300001)?t=val[i]-1:t%=val[i]),(t<ans[i])?ans[i]=t:1;
}
}
for(i=1;i<=n;++i)
if(op[i]=='B') printf("%d\n",ans[i]);
return 0;
}

bzoj 4320: ShangHai2006 Homework的更多相关文章

  1. BZOJ.4320.[ShangHai2006]Homework(根号分治 分块)

    BZOJ \(\mathbb{mod}\)一个数\(y\)的最小值,可以考虑枚举剩余系,也就是枚举区间\([0,y),[y,2y),[2y,3y)...\)中的最小值(求后缀最小值也一样)更新答案,复 ...

  2. bzoj 4320: ShangHai2006 Homework【分块】

    按根号300000=m分情况讨论 查询是,当x小于等于m,那么可以暴力记录直接出解:否则,用分块维护区间值,查询的时候以x为步长跳根号m次取最小值即可 还有一种并查集方法,来自https://www. ...

  3. 4320: ShangHai2006 Homework

    4320: ShangHai2006 Homework 链接 分析: 分块.对权值模数进行分块,模数小于$\sqrt V$的($V$为权值上界),暴力处理. 模数大于$\sqrt V$的,设模数是k, ...

  4. 【BZOJ4320】ShangHai2006 Homework 分段+并查集

    [BZOJ4320]ShangHai2006 Homework Description   1:在人物集合 S 中加入一个新的程序员,其代号为 X,保证 X 在当前集合中不存在.    2:在当前的人 ...

  5. 【bzoj4320】【ShangHai2006 Homework】【并查集+离线处理】

    ShangHai2006 Homework Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 918  Solved: 460[Submit][Statu ...

  6. BZOJ4320 : ShangHai2006 Homework

    取$M=\sqrt{300000}$. 设$g[i]$表示程序员的$\bmod i$最小的值. 若$Y<M$,那么可以在$O(M)$时间内完成对所有$g[i]$的修改,$O(1)$时间内完成查询 ...

  7. [BZOJ4320][ShangHai2006]Homework(根号分治+并查集)

    对于<=sqrt(300000)的询问,对每个模数直接记录结果,每次加入新数时暴力更新每个模数的结果. 对于>sqrt(300000)的询问,枚举倍数,每次查询大于等于这个倍数的最小数是多 ...

  8. BZOJ4320 ShangHai2006 Homework(分块+并查集)

    考虑根号分块.对于<√3e5的模数,每加入一个数就暴力更新最小值:对于>√3e5的模数,由于最多被分成√3e5块,查询时对每一块找最小值,这用一些正常的DS显然可以做到log,但不太跑得过 ...

  9. 【bzoj4320】ShangHai2006 Homework

    若Y小于等于sqrt(300000),暴力,对所有的插入的数都更新mn[i]. 若Y大于sqrt(300000),枚举kY,用并查集维护>=i的第一个数,这样只支持删除操作是O(1),然后倒着枚 ...

随机推荐

  1. Project server 2016 “没有为此项目配置网站”错误处理

    问题: 没有为此项目配置网站. There is no site configured for this project 解决办法: 依次点击设置>PWA设置>连接到sharepoint网 ...

  2. Android中的Libraries以及Order and Export的使用。

    1Add JAR 从Eclipse的现有所有工程中,添加jar包到该工程下 2Add External JARs 从Eclipse外的其他的位置,添加jar包到该工程下 3Add Variable 增 ...

  3. react-native DatePicker日期选择组件的实现

    本教程的实现效果如下: 为了实现其淡入/淡出的覆盖效果, 还有取消按钮, 在此用了一个三方的组件, 大家可以先安装一下: 三方组件的地址:https://github.com/eyaleizenber ...

  4. UICollectionViewCell--查找cell上的按钮点击后,对应的是哪个cell

    实际写项目会碰到各种各样的问题,废话不多说 按钮添加到cell时,根据是直接添加到self还是self.contentView上,在点击方法里找到btn的父视图 我是直接添加到self上,所以只有一层 ...

  5. 如何在 Evernote 中支持代码高亮

    Evernote 本身不支持代码高亮,在 Apple App-Store 上有一个建立在 Evernote 上的 EverCode,可以支持代码高亮,需要付费.虽然只有¥5,但是这个 App 似乎只能 ...

  6. Node.js 教程 02 - 经典的Hello World

    前言: Node.js的介绍.安装及配置,上一节都已经介绍过了,如果有不清楚的也可以留言或者直接问度娘. 本节: 本节主要以一个简单的例子简单体验一下Node.js,用到了两种方法.下面会介绍. 总之 ...

  7. SQL SERVER 2008复制数据库时发生执行SQL Server代理作业错误

    1. 情况说明 在利用SQL SERVER数据库复制向导,能够很方便的将一个数据库从一台服务器复制到另一台服务器上,具体操作步骤也十分简单. 不过在实际操作过程常发生“执行SQL SERVER代理作业 ...

  8. Mysql常用函数,难点,注意

    一.数学函数 ABS(x)   返回x的绝对值 BIN(x)   返回x的二进制(OCT返回八进制,HEX返回十六进制) CEILING(x)   返回大于x的最小整数值 EXP(x)   返回值e( ...

  9. kd树和knn算法的c语言实现

    基于kd树的knn的实现原理可以参考文末的链接,都是一些好文章. 这里参考了别人的代码.用c语言写的包括kd树的构建与查找k近邻的程序. code: #include<stdio.h> # ...

  10. 用nginx一分钟实现文件服务器

    在局域网内和同事共享文件的好方法 1 安装nginx sudo apt-get install nginx 2 创建conf文件 sudo gedit /etc/nginx/conf.d/file_s ...