题目描述

HH 有一串由各种漂亮的贝壳组成的项链。HH 相信不同的贝壳会带来好运,所以每次散步完后,他都会随意取出一段贝壳,思考它们所表达的含义。HH 不断地收集新的贝壳,因此,他的项链变得越来越长。有一天,他突然提出了一个问题:某一段贝壳中,包含了多少种不同的贝壳?这个问题很难回答……因为项链实在是太长了。于是,他只好求助睿智的你,来解决这个问题。

输入输出格式

输入格式:

第一行:一个整数N,表示项链的长度。

第二行:N 个整数,表示依次表示项链中贝壳的编号(编号为0 到1000000 之间的整数)。

第三行:一个整数M,表示HH 询问的个数。

接下来M 行:每行两个整数,L 和R(1 ≤ L ≤ R ≤ N),表示询问的区间。

输出格式:

M 行,每行一个整数,依次表示询问对应的答案。

输入输出样例

输入样例#1:

  1. 6
  2. 1 2 3 4 3 5
  3. 3
  4. 1 2
  5. 3 5
  6. 2 6
输出样例#1:

  1. 2
  2. 2
  3. 4

说明

数据范围:

对于100%的数据,N <= 50000,M <= 200000。

解题思路

  在线解法听说可以用主席树?那玩意太高端,本蒟蒻不会……2019年7月30日21:10:59更新,现在会了HDU 5919 Sequence ll

  离线解法主要有两种——一种是求区间和的奇技淫巧,另一种是分块莫队。我用的是前一种。

  单点修改求区间和的方法挺多,这里用的树状数组(方便、简单)

  离线,先把所有询问存下来,然后对所有询问按照左端点升序排序(右端点排不排无所谓的啦,反正又不影响结果)。

  然后记录下每种颜色的下一个相同颜色所在的位置,用next[i]表示。

  然后在树状数组(开始时全部是0)中把每种颜色第一次出现的位置标记为1,然后就可以按排好的顺序处理所有询问了。

  一个个询问可以看作是一个滑动窗口在项链上滑动,读取窗口内的颜色信息。

  窗口向右移动以后,左端点的左边那些第一次出现的颜色在窗口中就表示不出来了,这时就要把左端点以左的标记为1颜色全部“弄”到下一个颜色相同的点上(next[i])。

  定义一个变量$l$,然后按之前的左端点递增的顺序处理询问。

  让$l$从1开始不断增加,直到到达第$i$个询问所要求的左端点前一位,这部分的作用是把当前询问区间的左边那些1全部“弄”到后面。然后统计这次询问的答案,线段树求这个询问区间的区间和就是答案啦!

----------------------------------------------------分割线-------------------------------------------------------

  2019年03月02日16:57:57。我当年写的啥玩意……丢个我现在看得懂的链接。为啥我的代码比黄学长长那么多……2019年03月02日17:09:23把上面的描述更新了一波,好像好懂多了(说不定一年多以后我又看不懂了)。

----------------------------------------------------分割线-------------------------------------------------------

  我来填坑啦!并不会输公式,勉强看看吧

  莫队离线处理询问区间(li,ri),如果知道了(li,ri)的答案,那我们就能很快知道(li-1,ri)(li+1,ri)(li,ri-1)(li,ri+1)的答案,那么在已知(l[i],r[i])的答案的情况下,我们需要O(abs(l[i]-l[i+1])+abs(r[i]-r[i+1]))的时间暴力得到(l[i+1],r[i+1])的答案。如何使转移代价最少?一种方法是按曼哈顿最小生成树的dfs序转移,但是难度过高,于是——

  对于每个读入的询问(l[i],r[i]),我们设pos[i]=l[i]/sqrt(n),(这就是传说中的分块)以pos[i]为第一关键字,r[i]为第二关键字对所有询问进行排序,依次处理询问,这样能跑得很快。时间复杂度变成了O(n^(3/2))。

  证明和代码网上遍地都是,这里就不贴了(逃)。下面的代码思路是树状数组的。

源代码

  1. #include<cstdio>
  2. #include<algorithm>
  3. #define lowbit(x) (x)&(-x)
  4.  
  5. int n,m,mx=-;
  6. int a[]={},next[]={};
  7. int p[]={};//类似一个桶,装每种颜色第一次出现的位置
  8.  
  9. int c[]={};//树状数组
  10. int query(int pos)
  11. {
  12. int ans=;
  13. while(pos)
  14. {
  15. ans+=c[pos];
  16. pos-=lowbit(pos);
  17. }
  18. return ans;
  19. }
  20. void add(int pos,int x)
  21. {
  22. while(pos<=n)
  23. {
  24. c[pos]+=x;
  25. pos+=lowbit(pos);
  26. }
  27. }
  28.  
  29. struct Ask{
  30. int l,r,id,ans;
  31. }ask[];
  32. bool cmp1(const Ask & a,const Ask & b)
  33. {
  34. return a.l==b.l?a.r<b.r:a.l<b.l;
  35. }
  36. bool cmp2(const Ask & a,const Ask & b)
  37. {
  38. return a.id<b.id;
  39. }
  40.  
  41. int main()
  42. {
  43. scanf("%d",&n);
  44. for(int i=;i<=n;i++) scanf("%d",a+i),mx=std::max(a[i],mx);
  45. for(int i=n;i>;i--)//预处理出next和p
  46. {
  47. next[i]=p[a[i]];
  48. p[a[i]]=i;
  49. }
  50. for(int i=;i<=mx;i++) if(p[i])add(p[i],);
  51.  
  52. scanf("%d",&m);
  53. for(int i=,l,r;i<=m;i++)
  54. {
  55. scanf("%d%d",&l,&r);
  56. ask[i]={l,r,i,};
  57. }
  58.  
  59. std::stable_sort(ask+,ask++m,cmp1);
      //用归并的原因是,apio2017,第二题交互题,某部分分可以用stl排序的比较函数发出询问,然后就能得到结果。 这个页面三分之二的位置
      //询问次数有限,用归并才能以较少的比较函数调用次数卡过去,好些大佬就这样被卡了85。当时半懂不懂的,apio以后用了好久归并,不敢用快排#捂脸
  60. for(int i=,ll=;i<=m;i++)
  61. {
  62. while(ll<ask[i].l)
  63. {
  64. if(next[ll]) add(next[ll],);
  65. ll++;
  66. }
  67. ask[i].ans=query(ask[i].r)-query(ask[i].l-);
  68. }
  69.  
  70. std::stable_sort(ask+,ask++m,cmp2);
  71. for(int i=;i<=m;i++)
  72. printf("%d\n",ask[i].ans);
  73.  
  74. return ;
  75. }

洛谷 P1972 BZOJ 1878 [SDOI2009]HH的项链的更多相关文章

  1. BZOJ 1878: [SDOI2009]HH的项链

    1878: [SDOI2009]HH的项链 Time Limit: 4 Sec  Memory Limit: 64 MBSubmit: 3548  Solved: 1757[Submit][Statu ...

  2. BZOJ 1878: [SDOI2009]HH的项链 离线树状数组

    1878: [SDOI2009]HH的项链 Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://www.lydsy.com/JudgeOnline/p ...

  3. Bzoj 1878: [SDOI2009]HH的项链 莫队

    1878: [SDOI2009]HH的项链 Time Limit: 4 Sec  Memory Limit: 64 MBSubmit: 2717  Solved: 1363[Submit][Statu ...

  4. BZOJ 1878: [SDOI2009]HH的项链( BIT )

    离线处理 , 记下询问的左右端点并排序 , 然后可以利用树状数组 , 保证查询区间时每种颜色只计算一次 ------------------------------------------------ ...

  5. BZOJ 1878 [SDOI2009]HH的项链 【莫队】

    任意门:https://www.lydsy.com/JudgeOnline/problem.php?id=1878 1878: [SDOI2009]HH的项链 Time Limit: 4 Sec  M ...

  6. 【洛谷】1972:[SDOI2009]HH的项链【莫队+树状数组】

    P1972 [SDOI2009]HH的项链 题目背景 无 题目描述 HH 有一串由各种漂亮的贝壳组成的项链.HH 相信不同的贝壳会带来好运,所以每次散步完后,他都会随意取出一段贝壳,思考它们所表达的含 ...

  7. BZOJ 1878 [SDOI2009]HH的项链 (主席树 或 莫队算法)

    题目链接  HH的项链 这道题可以直接上主席树的模板 #include <bits/stdc++.h> using namespace std; #define rep(i, a, b) ...

  8. bzoj 1878 [SDOI2009]HH的项链(离线处理+BIT)

    Description HH有一串由各种漂亮的贝壳组成的项链.HH相信不同的贝壳会带来好运,所以每次散步 完后,他都会随意取出一段贝壳,思考它们所表达的含义.HH不断地收集新的贝壳,因此, 他的项链变 ...

  9. bzoj 1878: [SDOI2009]HH的项链 ——树状数组+ 差分

    Description HH有一串由各种漂亮的贝壳组成的项链.HH相信不同的贝壳会带来好运,所以每次散步 完后,他都会随意取出一 段贝壳,思考它们所表达的含义.HH不断地收集新的贝壳,因此他的项链变得 ...

随机推荐

  1. LuoguP3261 [JLOI2015]城池攻占

    题目描述 小铭铭最近获得了一副新的桌游,游戏中需要用 m 个骑士攻占 n 个城池.这 n 个城池用 1 到 n 的整数表示.除 1 号城池外,城池 i 会受到另一座城池 fi 的管辖,其中 fi &l ...

  2. 使用 Jenkins + GitHub + Nginx + HTTPS 搭建静态网站

    参考https://www.imooc.com/article/20079 http://www.haoduoyu.cc/

  3. discuz的cutstr函数

    function cutstr($string, $length, $dot = ' ...') { if(strlen($string) <= $length) { return $strin ...

  4. Spinner的样式大致简介

    Spinner Spinner 是一个列表选择框,会在用户选择后,展示一个列表供用户进行选择.Spinner是ViewGroup的间接子类,它和其他的Android控件一样,数据需要使用Adapter ...

  5. 鼠标单击到 img行的时候图片隐藏方案

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  6. Java&Xml教程(五)使用SAX方式解析XML文件

    Java SAX解析机制为我们提供了一系列的API来处理XML文件,SAX解析和DOM解析方式不太一样,它并不是將XML文件内容一次性全部加载,而是连续的部分加载. javax.xml.parsers ...

  7. [Android]异常7-Error:Configuration with name 'default' not found.

    背景:使用SVN更新代码,运行出现 异常原因: 可能一>缺少Modules 解决办法有: 解决一>Android Studio切换为Project,settings.gradle中引用和现 ...

  8. Power Designer逆向操作(从mysql5.0生成数据库的物理模型)

    Power Designer逆向操作(从mysql5.0生成数据库的物理模型) 环境:powderdesigner12.5:mysql5.0 步骤: 1.  为指定的数据库配置MySQL的ODBC数据 ...

  9. C# 获得星期几

    var temp = System.DateTime.Today.ToString("dddd", new System.Globalization.CultureInfo(&qu ...

  10. GatewayWorker + LayIM实现即时聊天

    一.程序目录结构 二.代码展示 附LayIM开发文档:https://www.layui.com/doc/modules/layim.html 1.前端代码 <!DOCTYPE html> ...