花神喜欢步行游历各国,顺便虐爆各地竞赛。花神有一条游览路线,它是线型的,也就是说,所有游历国家呈一条线的形状排列,花神对每个国家都有一个喜欢程度(当然花神并不一定喜欢所有国家)。

每一次旅行中,花神会选择一条旅游路线,它在那一串国家中是连续的一段,这次旅行带来的开心值是这些国家的喜欢度的总和,当然花神对这些国家的喜欢程序并不是恒定的,有时会突然对某些国家产生反感,使他对这些国家的喜欢度 δ 变为 sqrt (δ)​(可能是花神虐爆了那些国家的 OI,从而感到乏味)。

现在给出花神每次的旅行路线,以及开心度的变化,请求出花神每次旅行的开心值。

输入格式

第一行是一个整数 N,表示有 N 个国家;

第二行有 N 个空格隔开的整数,表示每个国家的初始喜欢度 δi​;

第三行是一个整数 M,表示有 M 条信息要处理;

第四行到最后,每行三个整数 x,l,r,当 x=1 时询问游历国家 l 到 r 的开心值总和,也就是∑r​δi​ ,当 x=2 时国家 l 到 r 中每个国家的喜欢度δi​ 变为sqrt(δi)​​ 。

输出格式

每次 x=1 时,每行一个整数。表示这次旅行的开心度。

样例

样例输入

4
1 100 5 5
5
1 1 2
2 1 2
1 1 2
2 2 3
1 1 4

样例输出

101
11
11

数据范围与提示

对于全部数据,1≤n≤10^5,1≤m≤2×10^5,1≤l≤r≤n,0≤δi​≤10^9。

注:建议使用 sqrt 函数,且向下取整。

__________________________________________________________________________

懒惰标记为bool型,标记当前区域是否已经无需开方,也就是是否都是1或0.

bz[cur]=bz[cur<<1] && bz[cur<<1|1]

如果懒惰标记为1,则无需再做修改。

__________________________________________________________________________

 1 #include<bits/stdc++.h>
2 using namespace std;
3 const int maxn=1e5+10;
4 typedef long long ll;
5 ll sum[maxn<<2],a[maxn];
6 bool delt[maxn<<2];
7 ll n,m;
8 void build(ll cur,ll l,ll r)
9 {
10 if(l==r)
11 {
12 sum[cur]=a[l];
13 if(sum[cur]==0 || sum[cur]==1)delt[cur]=1;
14 return ;
15 }
16 ll mid=(l+r)>>1;
17 build(cur<<1,l,mid);
18 build(cur<<1|1,mid+1,r);
19 sum[cur]=sum[cur<<1]+sum[cur<<1|1];
20 delt[cur]=delt[cur<<1] && delt[cur<<1|1];
21 }
22 void change(ll cur,ll l,ll r,ll ql,ll qr)
23 {
24 if(delt[cur])return;
25 if(l==r)
26 {
27 sum[cur]=sqrt(sum[cur]);
28 if(sum[cur]==1 || sum[cur]==0)delt[cur]=1;
29 return ;
30 }
31 ll mid=(l+r)>>1;
32 if(ql<=mid)change(cur<<1,l,mid,ql,qr);
33 if(mid<qr)change(cur<<1|1,mid+1,r,ql,qr);
34 sum[cur]=sum[cur<<1]+sum[cur<<1|1];
35 delt[cur]=delt[cur<<1] && delt[cur<<1|1];
36 }
37 ll query(ll cur,ll l,ll r,ll ql,ll qr)
38 {
39 if(ql<=l && r<=qr)return sum[cur];
40 ll ans=0,mid=(l+r)>>1;
41 if(ql<=mid)ans+=query(cur<<1,l,mid,ql,qr);
42 if(mid<qr)ans+=query(cur<<1|1,mid+1,r,ql,qr);
43 return ans;
44 }
45 int main()
46 {
47 scanf("%lld",&n);
48 for(int i=1;i<=n;++i)scanf("%lld",a+i);
49 build(1,1,n);
50 scanf("%lld",&m);
51 for(int op,ql,qr,i=0;i<m;++i)
52 {
53 scanf("%d%d%d",&op,&ql,&qr);
54 if(op==1)printf("%lld\n",query(1,1,n,ql,qr));
55 else change(1,1,n,ql,qr);
56 }
57 return 0;
58 }

LOJ10128. 花神游历各国的更多相关文章

  1. BZOJ-3211花神游历各国 并查集+树状数组

    一开始想写线段树区间开方,简单暴力下,但觉得变成复杂度稍高,懒惰了,编了个复杂度简单的 3211: 花神游历各国 Time Limit: 5 Sec Memory Limit: 128 MB Subm ...

  2. BZOJ 3211: 花神游历各国( 线段树 )

    线段树...区间开方...明显是要处理到叶节点的 之前在CF做过道区间取模...差不多, 只有开方, 那么每个数开方次数也是有限的(0,1时就会停止), 最大的数10^9开方10+次也就不会动了.那么 ...

  3. BZOJ 3211: 花神游历各国【线段树区间开方问题】

    3211: 花神游历各国 Time Limit: 5 Sec  Memory Limit: 128 MBSubmit: 3514  Solved: 1306[Submit][Status][Discu ...

  4. bzoj3211花神游历各国 线段树

    3211: 花神游历各国 Time Limit: 5 Sec  Memory Limit: 128 MBSubmit: 4252  Solved: 1547[Submit][Status][Discu ...

  5. 【BZOJ】【3211】花神游历各国

    线段树/暴力 线段树区间开方 唉,我傻逼了一下,TLE了一发,因为没考虑到0的情况…… 好吧简单来说一下,线段树动态查询区间和大家都会做……比较麻烦的是这次的修改变成开方了,然而这并没有什么好虚的,注 ...

  6. BZOJ3211: 花神游历各国(线段树)

    3211: 花神游历各国 Time Limit: 5 Sec  Memory Limit: 128 MBSubmit: 5692  Solved: 2114[Submit][Status][Discu ...

  7. 【BZOJ3211】花神游历各国 并查集+树状数组

    [BZOJ3211]花神游历各国 Description Input Output 每次x=1时,每行一个整数,表示这次旅行的开心度 Sample Input 41 100 5 551 1 22 1 ...

  8. [BZOJ3211]花神游历各国&&[BZOJ3038] 上帝造题的七分钟2 树状数组+并查集

    3211: 花神游历各国 Time Limit: 5 Sec  Memory Limit: 128 MBSubmit: 4057  Solved: 1480[Submit][Status][Discu ...

  9. BZOJ3211花神游历各国

    BZOJ3211花神游历各国 BZOJ luogu 分块 记一个all表示该块是否全部<=1,如果all不为真就暴力修改 因为一个数被开根的次数不多,即使\(10^{12}\)只要开根6次也会变 ...

随机推荐

  1. [转载]Mybatis Generator最完整配置详解

    <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE generatorConfiguration ...

  2. 对象存储Backblaze B2作为ShareX图床的Windows及安卓端配置

    标题: 对象存储Backblaze B2作为ShareX图床的Windows及安卓端配置 作者: 梦幻之心星 sky-seeker@qq.com 标签: [对象存储,图床,Backblaze,Shar ...

  3. 聊一聊这个总下载量3603w的xss库,是如何工作的?

    上篇文章这一次,彻底理解XSS攻击讲解了XSS攻击的类型和预防方式,本篇文章我们来看这个36039K的XSS-NPM库(你没有看错就是3603W次, 36039K次,36,039,651次,数据来自h ...

  4. 改进你的c#代码的5个技巧(一)

    亲爱的读者,在这篇文章中,我提供了一些c#编程的最佳实践. 你是否在用户输入验证中使用异常处理机制? 如果是,那么你就是那个把你的项目执行速度降低了62倍的人.你不相信我吗?等几分钟;我来教你怎么做. ...

  5. 如何解决Visual Studio 首次调试 docker 的 vs2017u5 exists, deleting Opening stream failed, trying again with proxy settings

    前言 因为之前我电脑安装的是windows10家庭版,然而windows10家庭没有Hyper-v功能. 搜索了几篇windows10家庭版安装docker相关的博客,了解一些前辈们走过的坑. 很多人 ...

  6. JSF学习实战

    JSF是什么? JSF(JavaServer Faces)它是一个基于服务器端组件的用户界面框架. 它用于开发Web应用程序.它提供了一个定义良好的编程模型,由丰富的API和标签库组成.JSF API ...

  7. 你还不知道mysql中空值和null值的区别吗?

    前言 最近发现带的小伙伴写sql对于空值的判断方法不正确,导致程序里面的数据产生错误,在此进行一下整理,方便大家以后正确的判断空值.以下带来示例给大家进行讲解. 建表 create table tes ...

  8. CODING x 腾讯兔小巢,打破研发团队与用户反馈的最后一道壁垒

    任何产品的更新迭代都离不开用户的使用反馈.产品经理日常需要奔走到一线部门了解用户的使用反馈:一线运营或业务团队日常需要向产品经理转述用户的问题场景及催促需求的进度.中间需要消耗大量的精力来进行信息转达 ...

  9. wpf 在不同DPI下如何在DrawingVisual中画出清晰的图形

    环境Win10 VS2017 .Net Framework4.7.1   本文仅讨论在DrawingVisual中进行的画图.   WPF单位,系统DPI,显示器DPI三者的定义及关系 WPF单位:一 ...

  10. git 遇到 fatal: loose object xxxx (stored in .git/objects/cb/xxxx) is corrupt 问题

    我的git版本是2.3.x,用下面这个参考链接的方法也可以解决 参考blog