莫队,卡常数


题目地址

  • 思路

    • 设\(\text{Vis[i]}\)为元素\(\text{i}\)在区间\(\text{[L,R]}\)的出现次数

    • 考虑区间\(\text{[L,R]}\)和元素\(\text{i}\),首次取出的概率为\(\frac{Vis[i]}{R-L+1}\),再次取出的概率是\(\frac{Vis[i]-1}{R-L}\)

    • 对于区间\(\text{[L,R]}\),答案为\(\sum_{i=1}^{N}{\frac{Vis[i](Vis[i]-1)}{(R-L)*(R-L+1)}}\)。

    • 这样,每次给变\(\text{[L,R]}\),分子的变化可以通过对前、后两项的值做差得到:

      • 设X=Vis[i],有:

      \[(X+1)X-(X)(X-1)=2X
      \]

    • 莫队这样修改即可。

  • Code

    • /**************************************************************
      Problem: 2038
      User: Bj2002
      Language: C++
      Result: Accepted
      Time:11036 ms
      Memory:2584 kb
      ****************************************************************/ #include <stdio.h>
      #include <string.h>
      #include <algorithm>
      #define GC getchar()
      #define Clean(X,K) memset(X,K,sizeof(X))
      using namespace std ;
      int Qread () {
      int X = 0 ;
      char C = GC ;
      while (C > '9' || C < '0') C = GC ;
      while (C >='0' && C <='9') {
      X = X * 10 + C - '0' ;
      C = GC ;
      }
      return X ;
      }
      long long GCD(long long M, long long N) {
      while (N != 0) {
      long long T = M % N;
      M = N;
      N = T;
      }
      return M;
      }
      const int Maxn = 50005 ;
      int N , M , A[Maxn] , Vis[Maxn] ;
      long long Ans[Maxn] , Sum[Maxn];
      struct Node {
      int Left , Right , Place;
      };
      Node Q[Maxn] ;
      bool Cmp (const Node &X , const Node &Y) {
      if (X.Left != Y.Left ) return X.Left < Y.Left ;
      if (X.Left & 1) return X.Right < Y.Right ;
      else return X.Right > Y.Right ;
      }
      bool Cmp2 (const Node &X , const Node &Y) {
      return X.Place < Y.Place ;
      }
      void Qwrite(int X) {
      if(X > 9) Qwrite(X / 10);
      putchar(X % 10 + '0');
      } int main () {
      // freopen ("P1494.in" , "r" , stdin) ;
      // freopen ("P1494.out", "w" , stdout) ;
      N = Qread () , M = Qread ();
      for (int i = 1 ; i <= N; ++ i) A[i] = Qread () ;
      for (int i = 1 ; i <= M; ++ i) Q[i].Left = Qread () , Q[i].Right = Qread () , Q[i].Place = i ;;
      sort (Q + 1 , Q + 1 + M , Cmp) ;
      Clean (Vis , 0) ;
      int L , R ;
      long long Now = 0 ;
      L = R = Q[1].Left ;
      Vis[A[L]] = 1 ;
      for (int i = 1 ; i <= M; ++ i) {
      while (L < Q[i].Left ) {
      -- Vis[A[L]] ;
      Now -= (Vis[A[L]] << 1) ;
      ++ L ;
      }
      // cout << L <<' '<<R <<' '<<Now<<endl;
      while (R < Q[i].Right ) {
      ++ R ;
      Now += (Vis[A[R]] << 1) ;
      ++ Vis[A[R]] ;
      }
      // cout << L <<' '<<R <<' '<<Now<<endl;
      while (R > Q[i].Right ) {
      -- Vis[A[R]] ;
      Now -= (Vis[A[R]] << 1) ;
      -- R ;
      }
      // cout << L <<' '<<R <<' '<<Now<<endl;
      Ans[Q[i].Place] = Now , Sum[Q[i].Place ] = ((long long)Q[i].Right - Q[i].Left ) * (Q[i].Right - Q[i].Left + 1) ;
      }
      std :: sort (Q + 1 , Q + 1 + M , Cmp2) ;
      for (int i = 1 ; i <= M; ++ i) {
      if (Q[i].Left == Q[i].Right ) printf ("0/1\n") ;
      else {
      int K = GCD (Ans[i] , Sum[i]) ;
      Ans[i] /= K , Sum[i] /= K ;
      printf ("%lld/%lld\n" , Ans[i] , Sum[i]) ;
      }
      }
      fclose (stdin) , fclose (stdout) ;
      return 0 ;
      }

Thanks!

[题解] 2038: [2009国家集训队]小Z的袜子(hose)的更多相关文章

  1. Bzoj 2038: [2009国家集训队]小Z的袜子(hose) 莫队,分块,暴力

    2038: [2009国家集训队]小Z的袜子(hose) Time Limit: 20 Sec  Memory Limit: 259 MBSubmit: 5763  Solved: 2660[Subm ...

  2. BZOJ 2038: [2009国家集训队]小Z的袜子(hose) [莫队算法]【学习笔记】

    2038: [2009国家集训队]小Z的袜子(hose) Time Limit: 20 Sec  Memory Limit: 259 MBSubmit: 7687  Solved: 3516[Subm ...

  3. BZOJ 2038: [2009国家集训队]小Z的袜子(hose)

    2038: [2009国家集训队]小Z的袜子(hose) Time Limit: 20 Sec  Memory Limit: 259 MBSubmit: 7676  Solved: 3509[Subm ...

  4. 莫队算法 2038: [2009国家集训队]小Z的袜子(hose)

    链接:http://www.lydsy.com/JudgeOnline/problem.php?id=2038 2038: [2009国家集训队]小Z的袜子(hose) Time Limit: 20 ...

  5. BZOJ 2038: [2009国家集训队]小Z的袜子(hose) ( 莫队 )

    莫队..先按sqrt(n)分块, 然后按块的顺序对询问排序, 同块就按右端点排序. 然后就按排序后的顺序暴力求解即可. 时间复杂度O(n1.5) --------------------------- ...

  6. BZOJ 2038: [2009国家集训队]小Z的袜子(hose) 分块

    分块大法好 2038: [2009国家集训队]小Z的袜子(hose) Time Limit: 20 Sec  Memory Limit: 259 MB Submit: 2938  Solved: 13 ...

  7. BZOJ 2038: [2009国家集训队]小Z的袜子(hose)【莫队算法裸题&&学习笔记】

    2038: [2009国家集训队]小Z的袜子(hose) Time Limit: 20 Sec  Memory Limit: 259 MBSubmit: 9894  Solved: 4561[Subm ...

  8. 2038: [2009国家集训队]小Z的袜子(hose) (莫队算法)

    题目链接: http://www.lydsy.com/JudgeOnline/problem.php?id=2038 专题练习: http://acm.hust.edu.cn/vjudge/conte ...

  9. 2038: [2009国家集训队]小Z的袜子(hose)

    2038: [2009国家集训队]小Z的袜子(hose) Time Limit: 20 Sec  Memory Limit: 259 MBSubmit: 9472  Solved: 4344 Desc ...

随机推荐

  1. 剑指Offer常见问题整理

    1 在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序.请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数.(来自牛客网,剑指offer) ...

  2. 图解HTTPS建立过程

    阅读目录 准备工作(对应图中prepare1234) 发起链接 最后 关于网络安全加密的介绍可以看之前文章: 1. 网络安全——数据的加密与签名,RSA介绍2. Base64编码.MD5.SHA1-S ...

  3. SSH概念及常用操作汇总

    工作有一段时间了,经常用SSH登录远程机器,但对原理一直不是很了解,所以查阅了一些资料,写个小结. 一. SSH是什么? SSH的全称是Secure Shell, 是一种“用来在不安全的网络上安全地运 ...

  4. OFFICE2007软件打开word时出现SETUP ERROR的解决方法

    今天打开word时出现以下错误窗口: 在度娘上找了一下解决方案,原来每次打开word时都会启动一些无用的东西,找到这些东西的路径D:\Program Files\Common Files\micros ...

  5. VS编译代码未通过,常见问题。

    问题一:LNK2028 这个问题一般是什么函数在哪里被引用.修改的方法是:先检查是否包含头文件,如果已经包含了头文件,则检查在源文件的"import.cpp"中是否包含了该lib文 ...

  6. loj6271「长乐集训 2017 Day10」生成树求和 加强版

    又是一个矩阵树套多项式的好题. 这里我们可以对每一位单独做矩阵树,但是矩阵树求的是边权积的和,而这里我们是要求加法,于是我们i将加法转化为多项式的乘法,其实这里相当于一个生成函数?之后如果我们暴力做的 ...

  7. 【莫比乌斯反演】BZOJ2820 YY的GCD

    Description 求有多少对(x,y)的gcd为素数,x<=n,y<=m.n,m<=1e7,T<=1e4. Solution 因为题目要求gcd为素数的,那么我们就只考虑 ...

  8. Pandas 错误笔记(持续更新)

    更新至2018.5.1 字典生成DataFrame 今天一个字典生成一个DataFrame,采用了以下形式,每一个value都是一个数(不是vector) df = pd.DataFrame({ 'i ...

  9. 关于throw、throws、try--catch的问题

    首先回顾概念 throws表示出现异常的一种可能性,并不一定会发生这些异常 throw则是抛出了异常,执行throw则一定抛出了某种异常 try--catch try语句用大括号{}指定了一段代码,该 ...

  10. CountDownLatch和CyclicBarrier 区别

    CountDownLatch : 一个线程(或者多个), 等待另外N个线程完成某个事情之后才能执行. CyclicBarrier        : N个线程相互等待,任何一个线程完成之前,所有的线程都 ...