BZOJ3211花神游历各国
BZOJ3211花神游历各国
BZOJ
luogu
分块
记一个all表示该块是否全部<=1,如果all不为真就暴力修改
因为一个数被开根的次数不多,即使\(10^{12}\)只要开根6次也会变成1,所以复杂度是可以证明的
注意BZOJ数据含0
#define ll long long
#include<bits/stdc++.h>
using namespace std;
const int N=1e5+5;
int re(){
int x=0,w=1;char ch=getchar();
while(ch<'0'||ch>'9'){if(ch=='-')w=-1;ch=getchar();}
while(ch>='0'&&ch<='9')x=x*10+ch-'0',ch=getchar();
return x*w;
}
int n,m,B,a[N],b[N];
bool all[N];
ll sum[N];
bool check(int x){
for(int i=(x-1)*B+1;i<=min(n,x*B);i++)
if(a[i]!=1&&a[i])return 0;
return 1;
}
void modify(int l,int r){
if(!all[b[l]]){
for(int i=l;i<=min(r,b[l]*B);i++){
if(a[i]==1||!a[i])continue;
int sq=sqrt(a[i]);
sum[b[i]]-=a[i]-sq;a[i]=sq;
}
if(check(b[l]))all[b[l]]=1;
}
if(b[l]!=b[r]){
if(!all[b[r]]){
for(int i=(b[r]-1)*B+1;i<=r;i++){
if(a[i]==1||!a[i])continue;
int sq=sqrt(a[i]);
sum[b[i]]-=a[i]-sq;a[i]=sq;
}
if(check(b[r]))all[b[r]]=1;
}
}
for(int i=b[l]+1;i<b[r];i++){
if(all[i])continue;
for(int j=(i-1)*B+1;j<=i*B;j++){
if(a[j]==1||!a[j])continue;
int sq=sqrt(a[j]);
sum[i]-=a[j]-sq;a[j]=sq;
}
if(check(i))all[i]=1;
}
}
ll query(int l,int r){
ll res=0;
for(int i=l;i<=min(r,b[l]*B);i++)res+=a[i];
if(b[l]!=b[r]){
for(int i=(b[r]-1)*B+1;i<=r;i++)res+=a[i];
}
for(int i=b[l]+1;i<b[r];i++)res+=sum[i];
return res;
}
int main(){
n=re();B=sqrt(n);
for(int i=1;i<=n;i++){
a[i]=re(),b[i]=(i-1)/B+1;
sum[b[i]]+=a[i];
}
m=re();
while(m--){
int k=re(),l=re(),r=re();
if(k==2)modify(l,r);
else printf("%lld\n",query(l,r));
}
return 0;
}
BZOJ3211花神游历各国的更多相关文章
- bzoj3211花神游历各国&&bzoj3038上帝造题的七分钟2*
bzoj3211花神游历各国 题意: n个数的序列,m个操作,操作两种:区间开根(向下取整)和区间求和.n≤100000,m≤200000,序列中的数非负且≤109. 题解: 一个≤109的数开6次根 ...
- bzoj3211 花神游历各国 线段树,势能分析
[bzoj3211]花神游历各国 2014年3月17日2,7230 Description Input Output 每次x=1时,每行一个整数,表示这次旅行的开心度 Sample Input ...
- BZOJ-3211花神游历各国 并查集+树状数组
一开始想写线段树区间开方,简单暴力下,但觉得变成复杂度稍高,懒惰了,编了个复杂度简单的 3211: 花神游历各国 Time Limit: 5 Sec Memory Limit: 128 MB Subm ...
- bzoj3211花神游历各国 线段树
3211: 花神游历各国 Time Limit: 5 Sec Memory Limit: 128 MBSubmit: 4252 Solved: 1547[Submit][Status][Discu ...
- BZOJ3211: 花神游历各国(线段树)
3211: 花神游历各国 Time Limit: 5 Sec Memory Limit: 128 MBSubmit: 5692 Solved: 2114[Submit][Status][Discu ...
- [BZOJ3211]花神游历各国&&[BZOJ3038] 上帝造题的七分钟2 树状数组+并查集
3211: 花神游历各国 Time Limit: 5 Sec Memory Limit: 128 MBSubmit: 4057 Solved: 1480[Submit][Status][Discu ...
- bzoj3211: 花神游历各国(线段树) 同codevs2492
3211: 花神游历各国 Time Limit: 5 Sec Memory Limit: 128 MBSubmit: 3628 Solved: 1326[Submit][Status][Discu ...
- [BZOJ3211]:花神游历各国(小清新线段树)
题目传送门 题目描述: 花神喜欢步行游历各国,顺便虐爆各地竞赛.花神有一条游览路线,它是线型的,也就是说,所有游历国家呈一条线的形状排列,花神对每个国家都有一个喜欢程度(当然花神并不一定喜欢所有国家) ...
- BZOJ3211 花神游历各国 并查集 树状数组
欢迎访问~原文出处——博客园-zhouzhendong 去博客园看该题解 题目传送门 - BZOJ3211 题意概括 有n个数形成一个序列. m次操作. 有两种,分别是: 1. 区间开根(取整) 2. ...
随机推荐
- ssh免密码登录之分发密钥
ssh免密码登录之分发密钥 1.ssh免密码登录 密码登录和密钥登录有什么不同? 密码登录(口令登录),每次登录都需要发送密码(ssh) 密钥登录,分为公钥和私钥,公钥相当于锁,私钥相当于钥匙 1.1 ...
- How to use Variables in different component
1. In Script Task component Set Value: Dts.Variables["ErrorMsg"].Value = string.Format(&qu ...
- 文件压缩和解压 FileStream GZipStream
using (FileStream reader=new FileStream (@"c:\1.txt",FileMode.Open,FileAccess.Read)) { usi ...
- 【VBA】切换引用样式
在Excle中有两种引用方式,例如:第一行第一列的单元格可以是:A1 也可以是R1C1 切换引用样式的代码如下: Sub 切换引用样式() Application.ReferenceStyle = ...
- c语言字符串赋值
char *p="asdf";能运行 定义一个字符指针,并用它指向常量字符串"asdf"的首地址 char *p;p="asdf"; 能运行 ...
- 单机Redis实现分布式互斥锁
代码地址如下:http://www.demodashi.com/demo/12520.html 0.准备工作 0-1 运行环境 jdk1.8 gradle 一个能支持以上两者的代码编辑器,作者使用的是 ...
- sql语句偶记录
查看表结构: show FULL COLUMNS FROM tablename;
- karma + phantom + mocha + sion + chai + nightwatch + selenium2(webdriver) 测试框架学习
第三方的教程传送门 https://segmentfault.com/a/1190000004558796 karma # github https://github.com/karma-runner ...
- IOS与安卓的远程调试
本地调试H5页面方案总结 http://www.jianshu.com/p/a43417b28280 Fiddler 手机抓包 http://blog.csdn.net/gld824125233/ar ...
- CCKiller:Linux轻量级CC攻击防御工具,秒级检查、自动拉黑和释放 《CCKiller:Linux轻量级CC攻击防御工具,秒级检查、自动拉黑和释放》来自张戈博客
张戈博客很久以前分享过一个CC攻击的防御脚本,写得不怎么样,不过被51CTO意外转载了.博客从此走上了经常被人拿来练手的不归之路. 当然,还是有不少朋友在生产环境使用,并且会留言询问相关问题.根据这些 ...