BZOJ3211花神游历各国

BZOJ

luogu

分块

记一个all表示该块是否全部<=1,如果all不为真就暴力修改

因为一个数被开根的次数不多,即使\(10^{12}\)只要开根6次也会变成1,所以复杂度是可以证明的

注意BZOJ数据含0

  1. #define ll long long
  2. #include<bits/stdc++.h>
  3. using namespace std;
  4. const int N=1e5+5;
  5. int re(){
  6. int x=0,w=1;char ch=getchar();
  7. while(ch<'0'||ch>'9'){if(ch=='-')w=-1;ch=getchar();}
  8. while(ch>='0'&&ch<='9')x=x*10+ch-'0',ch=getchar();
  9. return x*w;
  10. }
  11. int n,m,B,a[N],b[N];
  12. bool all[N];
  13. ll sum[N];
  14. bool check(int x){
  15. for(int i=(x-1)*B+1;i<=min(n,x*B);i++)
  16. if(a[i]!=1&&a[i])return 0;
  17. return 1;
  18. }
  19. void modify(int l,int r){
  20. if(!all[b[l]]){
  21. for(int i=l;i<=min(r,b[l]*B);i++){
  22. if(a[i]==1||!a[i])continue;
  23. int sq=sqrt(a[i]);
  24. sum[b[i]]-=a[i]-sq;a[i]=sq;
  25. }
  26. if(check(b[l]))all[b[l]]=1;
  27. }
  28. if(b[l]!=b[r]){
  29. if(!all[b[r]]){
  30. for(int i=(b[r]-1)*B+1;i<=r;i++){
  31. if(a[i]==1||!a[i])continue;
  32. int sq=sqrt(a[i]);
  33. sum[b[i]]-=a[i]-sq;a[i]=sq;
  34. }
  35. if(check(b[r]))all[b[r]]=1;
  36. }
  37. }
  38. for(int i=b[l]+1;i<b[r];i++){
  39. if(all[i])continue;
  40. for(int j=(i-1)*B+1;j<=i*B;j++){
  41. if(a[j]==1||!a[j])continue;
  42. int sq=sqrt(a[j]);
  43. sum[i]-=a[j]-sq;a[j]=sq;
  44. }
  45. if(check(i))all[i]=1;
  46. }
  47. }
  48. ll query(int l,int r){
  49. ll res=0;
  50. for(int i=l;i<=min(r,b[l]*B);i++)res+=a[i];
  51. if(b[l]!=b[r]){
  52. for(int i=(b[r]-1)*B+1;i<=r;i++)res+=a[i];
  53. }
  54. for(int i=b[l]+1;i<b[r];i++)res+=sum[i];
  55. return res;
  56. }
  57. int main(){
  58. n=re();B=sqrt(n);
  59. for(int i=1;i<=n;i++){
  60. a[i]=re(),b[i]=(i-1)/B+1;
  61. sum[b[i]]+=a[i];
  62. }
  63. m=re();
  64. while(m--){
  65. int k=re(),l=re(),r=re();
  66. if(k==2)modify(l,r);
  67. else printf("%lld\n",query(l,r));
  68. }
  69. return 0;
  70. }

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

  1. bzoj3211花神游历各国&&bzoj3038上帝造题的七分钟2*

    bzoj3211花神游历各国 题意: n个数的序列,m个操作,操作两种:区间开根(向下取整)和区间求和.n≤100000,m≤200000,序列中的数非负且≤109. 题解: 一个≤109的数开6次根 ...

  2. bzoj3211 花神游历各国 线段树,势能分析

    [bzoj3211]花神游历各国 2014年3月17日2,7230 Description   Input   Output 每次x=1时,每行一个整数,表示这次旅行的开心度 Sample Input ...

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

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

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

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

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

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

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

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

  7. bzoj3211: 花神游历各国(线段树) 同codevs2492

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

  8. [BZOJ3211]:花神游历各国(小清新线段树)

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

  9. BZOJ3211 花神游历各国 并查集 树状数组

    欢迎访问~原文出处——博客园-zhouzhendong 去博客园看该题解 题目传送门 - BZOJ3211 题意概括 有n个数形成一个序列. m次操作. 有两种,分别是: 1. 区间开根(取整) 2. ...

随机推荐

  1. shopex下二级目录wordpress伪静态规则写法_SEO教程

    实这几天做服务器,做商城学到很多知识,只是太忙了没有空记录下来分享. 今天 商城的内容基本已经做好了.在shopex的二级目录下又建了一个wordpress来做SEO优化. 在wordpress后台做 ...

  2. Python - 连续替换(replace)的正則表達式(re)

    字符串连续替换, 能够连续使用replace, 也能够使用正則表達式. 正則表達式, 通过字典的样式, key为待替换, value为替换成, 进行一次替换就可以. 代码 # -*- coding: ...

  3. hdu 4512 吉哥系列故事——完美队形I(最长公共上升自序加强版)

    首先要去学习最长公共上升子序列LCIS.然后是对n*n效率的算法进行优化,这里要注意的是能够求出来的序列中间能够有一个最高的.刚開始将输入的数组进行逆置,写下来发现这可能存在问题. 只是详细是什么也没 ...

  4. CHM乱码解决方案!

    --希望对您有所帮助,闲暇之余请访问我的网店高清数据线 下载了一个日文的chm帮助文件,打开的时候,发现是乱码, CHM 文档不像IE浏览器一样,右键可以选择字符编码,非常不便. 原因可能是 CHM ...

  5. 【Excle数据透视表】如何利用图标集将销售数据划分为五个等级

    我们如何用图标集来直观看出订单情况呢? 现在有数据如下: 步骤 选中"订单列"→开始→条件格式→图标集→等级→ 此时,在每个数字前面都出现了一个等级符号了 查看预置五等级图标集的规 ...

  6. 安装Linux centos 时编辑选项

    将第上一步选择编辑之后出来的文字修改为:>vmlinuz initrd=initrd.img linux dd quiet 这里注意了:网上很多文章都说这一步改成“>vmlinuz ini ...

  7. appium for mac 安装与测试ios说明

    一.安装 安装dmg,可以自己下载appium-1.4.0.dmg或者找rtx我要,文件过大不能添加附件. Appium提供了一个doctor,运行appium-doctor 如果有问题,Fix it ...

  8. EF、Dapper、NHibernate等ORM框架的比较及优缺点

    什么是ORM? ORM的全称是Object Relational Mapping,即对象关系映射.它的实现思想就是将关系数据库中表的数据映射成为对象,以对象的形式展现,这样开发人员就可以把对数据库的操 ...

  9. 定时执行线程池ScheduledExecutorService的使用

    ScheduledExecutorService progressExecutorService = Executors.newScheduledThreadPool(1); ScheduledFut ...

  10. IP地址加时间戳加3位随机数

    工作中经常用到时间戳加上3位随机数获得唯一流水号,下面是代码~ package com.pb.viewer.filename; import java.text.SimpleDateFormat; i ...