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. ...
随机推荐
- EffectiveJava(19)导出常量的几种方式 - - 接口只用于定义类型
package com.classinteface.finalinterface; /** * 常量接口模式 java.io.ObjectStreamConstants * 这种模式会导致实现其的类将 ...
- AFN检測网络情况
问: I'm a bit lost on AFNetorking's Reachability and haven't found a lot of good information out ther ...
- windows pip源
首先在window的文件夹窗口输入 : %APPDATA% 然后在底下新建pip文件夹,然后到pip文件夹里面去新建个pip.ini,然后再里面输入内容 [global] timeout = 6000 ...
- UIWebView 加载网页、文件、 html
UIWebView 是用来加载加载网页数据的一个框.UIWebView可以用来加载pdf word doc 等等文件 生成webview 有两种方法,1.通过storyboard 拖拽 2.通过al ...
- excel表格快捷键
CTRL+A 全选 CTRL+B 加粗 CTRL+C 复制 CTRL+D 下拉(复制上一个单元格的格式和内容) CTRL+G 定位 CTRL+F ...
- 征信报告页面的input验证收集
https://ipcrs.pbccrc.org.cn/ function checkLoginName() { var loginName = $.trim($("#loginname&q ...
- Hibernate学习之二级缓存
© 版权声明:本文为博主原创文章,转载请注明出处 二级缓存 - 二级缓存又称“全局缓存”.“应用级缓存” - 二级缓存中的数据可适用范围是当前应用的所有会话 - 二级缓存是可插拔式缓存,默认是EHCa ...
- Dual Camera Info
一个摄像头解决不了的问题,那就用两个:对于双摄你需要了解这些 http://www.chengshiluntan.com/wg/a/20160715/6ca0343f59789235c9419887f ...
- 在Less中使用条件判断
好几个月都没写点什么东西了,被外派到Gov开发项目,老旧的系统让开发痛苦不堪,接口文档甚至是2011年的,感觉这几个月的时间都被浪费在做兼容处理上了,并且没学到什么东西,心里挺不是滋味.回到公司后才知 ...
- JFinal中json的使用
之前Java开发一直使用的是经典的ssh,去年接触了jfinal,觉得jfinal的魅力非常之大,让我无法自拔,现在还深深地陷在其中. 简单的介绍一下jfinal,jfinal短小精悍,让java有了 ...