1878: [SDOI2009]HH的项链

Time Limit: 4 Sec  Memory Limit: 64 MB
Submit: 4420  Solved: 2199
[Submit][Status][Discuss]

Description

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

Input

第一行:一个整数N,表示项链的长度。 
第二行:N个整数,表示依次表示项链中贝壳的编号(编号为0到1000000之间的整数)。 
第三行:一个整数M,表示HH询问的个数。 
接下来M行:每行两个整数,L和R(1 ≤ L ≤ R ≤ N),表示询问的区间。
N ≤ 50000,M ≤ 200000。

Output

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

Sample Input

6
1 2 3 4 3 5
3
1 2
3 5
2 6

Sample Output

2
2
4

//离线算法的话,比较好写,树状数组,或线段树维护一个前缀和

在线算法听说是主席树,目前还不会,以后会了,一定更

离线树状数组,思路是,先对贝壳数组模拟一个链表,nex[i] 记录每个位置右边最近的与该位置贝壳种类相同的贝壳的位置。

然后,pos[i] 记录 i 种类的贝壳最靠左的位置,然后,对每个存在种类的贝壳的最靠左位置(就是pos[i]),建一个树状数组,位置上有最靠左的贝壳就是 1 ,否则是0,这样是为了统计区间内的种类数!

然后,所有查询按左端点排序,枚举左端点,靠前面的链表更新树状数组,求前缀和。

其实感觉最大的耗时在于对询问的排序。。。mlog(m)

  1. /**************************************************************
  2. Problem: 1878
  3. User: happy_code
  4. Language: C++
  5. Result: Accepted
  6. Time:1780 ms
  7. Memory:8908 kb
  8. ****************************************************************/
  9.  
  10. #include <iostream>
  11. #include <stdio.h>
  12. #include <string.h>
  13. #include <algorithm>
  14. using namespace std;
  15. #define MXN 50005
  16. #define MXM 200005
  17. struct Que
  18. {
  19. int l,r;
  20. int id;
  21. int ans;
  22. }q[MXM];
  23.  
  24. int n,m;
  25. int a[MXN];
  26. int pos[];
  27. int nex[MXN];
  28. int tree[MXN];
  29.  
  30. int lowbit(int x){return x&(-x);}
  31. bool cmp1(const Que &a,const Que &b)
  32. {
  33. return a.l<b.l;
  34. }
  35. bool cmp2(const Que &a,const Que &b)
  36. {
  37. return a.id<b.id;
  38. }
  39.  
  40. void update(int x,int k)
  41. {
  42. for (int i=x;i<=n;i+=lowbit(i))
  43. tree[i]+=k;
  44. }
  45.  
  46. int query(int x)
  47. {
  48. int res=;
  49. for (int i=x;i>;i-=lowbit(i))
  50. res+=tree[i];
  51. return res;
  52. }
  53.  
  54. int main()
  55. {
  56. scanf("%d",&n);
  57. for (int i=;i<=n;i++)
  58. scanf("%d",&a[i]);
  59. for (int i=n;i>;i--)
  60. {
  61. nex[i]=pos[a[i]];
  62. pos[a[i]]=i;
  63. }
  64. for (int i=;i<;i++) //初始化
  65. if (pos[i]) update(pos[i],);
  66.  
  67. scanf("%d",&m);
  68. for (int i=;i<m;i++)
  69. {
  70. scanf("%d%d",&q[i].l,&q[i].r);
  71. q[i].id=i;
  72. }
  73. sort(q,q+m,cmp1);
  74.  
  75. int l=;
  76. for (int i=;i<m;i++)
  77. {
  78. while (l<q[i].l)
  79. {
  80. if (nex[l]) update(nex[l],);
  81. l++;
  82. }
  83. q[i].ans = query(q[i].r)-query(q[i].l-);
  84. }
  85.  
  86. sort(q,q+m,cmp2);
  87. for (int i=;i<m-;i++)
  88. printf("%d\n",q[i].ans);
  89. printf("%d\n",q[m-].ans);
  90. return ;
  91. }

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. BZOJ 1878 [SDOI2009]HH的项链 (主席树 或 莫队算法)

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

  7. 【BZOJ】1878: [SDOI2009]HH的项链(树状数组)

    http://www.lydsy.com/JudgeOnline/problem.php?id=1878 我太弱了,看题解才过的. 一开始看到此题,我想了想在线做法,但之后觉得这个想法可能是错的:维护 ...

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

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

  9. 1878. [SDOI2009]HH的项链【线段树 或 莫队】

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

随机推荐

  1. Android下的数据存储与訪问 --- 以文件的形式

    Android下的数据存储与訪问 --- 以文件的形式 1.1 储存文件存放在手机内存中: // *** 储存数据到 /data/data/包名/files/jxn.txt文件里 String dat ...

  2. B3:状态模式 State

    当一个对象内在状态改变时允许改变其行为,这个对象看起来像是改变了其类.状态模式主要解决当控制一个对象状态转换条件表达式过于复杂时的情况,把状态判断逻辑移到表示不同状态的一系列类中.如果状态判断很简单, ...

  3. C 实现strcmp,strcpy,strcat函数

    基于C语言的strcmp,strcpy,strcat函数的实现.C语言是一个程序猿的基础,一定要重视. char* strcat ( char * dst , const char * src ) { ...

  4. Android Exception 16(Error in ADT 23 Update)

    http://stackoverflow.com/questions/24445367/error-in-adt-23-update http://stackoverflow.com/question ...

  5. Java线程总结(转)

    作者的blog:(http://blog.matrix.org.cn/page/Kaizen) 首先要理解线程首先须要了解一些主要的东西,我们如今所使用的大多数操作系统都属于多任务,分时操作系统.正是 ...

  6. Linux在本地使用yum安装软件

    经常遇到有的linux服务器由于特殊原因,不能连接外网,但是经常需要安装一些软件,尤其是在编译一些包的时候经常由于没有安装一些依存包而报的各种各样的错误,当你找到依存的rpm包去安装的时候,又提示你有 ...

  7. php对象序列化总出错false

    php unserialize 返回false的解决方法 php 提供serialize(序列化) 与unserialize(反序列化)方法. 使用serialize序列化后,再使用unseriali ...

  8. Chap 2 Representing and Manipulating Information (CS:APP)

    -------------------------------------------------------------------------------------------------- A ...

  9. shell实现洗牌随机

    洗牌问题: 洗一副扑克,有什么好办法?既能洗得均匀,又能洗得快?即相对于一个文件来说怎样 高效率的实现乱序排列? 关于洗牌问题,其实已经有了一个很好的shell解法,这里另外给三个基于AWK的方法, ...

  10. FreeBSD编译安装emacs,不要用ports

    1. 解压emacs 2. 进入解压之后的目录,执行configure命令,大体配置如下: ./configure --with-x-toolkit=no --with-xpm=no --with-j ...