http://www.lightoj.com/volume_showproblem.php?problem=1085

题意:求一个序列的递增子序列个数。

思路:找规律可以发现,某个数作为末尾数的种类数为所有比它小的数的情况+1。使用树状数组查找即可。 C++11 的auto在Lightoj上不能用/.\

  1. /** @Date : 2016-12-01-21.58
  2. * @Author : Lweleth (SoungEarlf@gmail.com)
  3. * @Link : https://github.com/
  4. * @Version :
  5. */
  6.  
  7. #include<bits/stdc++.h>
  8. #define LL long long
  9. #define PII pair<int ,int>
  10. #define MP(x, y) make_pair((x),(y))
  11. #define fi first
  12. #define se second
  13. #define PB(x) push_back((x))
  14. #define MMG(x) memset((x), -1,sizeof(x))
  15. #define MMF(x) memset((x),0,sizeof(x))
  16. #define MMI(x) memset((x), INF, sizeof(x))
  17. using namespace std;
  18.  
  19. const int INF = 0x3f3f3f3f;
  20. const int N = 1e5+20;
  21. const int mod = 1000000007;
  22.  
  23. int C[N], a[N];
  24.  
  25. void add(int p, int v)
  26. {
  27. while(p < N)
  28. {
  29. C[p] += v;
  30. C[p] %= mod;
  31. p += (-p) & p;
  32. }
  33. }
  34.  
  35. int sum(int p)
  36. {
  37. int ans = 0;
  38. while(p)
  39. {
  40. ans += C[p];
  41. ans %= mod;
  42. p -= (-p) & p;
  43. }
  44. return ans;
  45. }
  46. int main()
  47. {
  48. int T;
  49. int cnt = 0;
  50. cin >> T;
  51. while(T--)
  52. {
  53. MMF(C);
  54. int n;
  55. scanf("%d", &n);
  56.  
  57. map<int , int>q;
  58.  
  59. for(int i = 1; i <= n; i++)
  60. {
  61. scanf("%d", &a[i]);
  62. q[a[i]] = 1;
  63. }
  64.  
  65. int c = 1;
  66. for(auto i = q.begin(); i != q.end(); i++)
  67. i->se = c++;
  68.  
  69. /*map<int , int>::iterator it;
  70. for( it = q.begin(); it != q.end(); it++)
  71. it->se = c++;*/
  72. for(int i = 1; i <= n; i++)//找规律可以发现,某个数作为末尾数的种类数为所有比它小的数的情况+1
  73. {
  74. int x = q[a[i]];
  75. add(x, sum(x - 1) + 1);
  76. }
  77. printf("Case %d: %d\n", ++cnt, sum(c - 1));
  78. }
  79. return 0;
  80. }

LightOJ 1085 - All Possible Increasing Subsequences 树状数组+离散的更多相关文章

  1. Codeforces 597C. Subsequences (树状数组+dp)

    题目链接:http://codeforces.com/contest/597/problem/C 给你n和数(1~n各不同),问你长为k+1的上升自序列有多少. dp[i][j] 表示末尾数字为i 长 ...

  2. [Codeforces261D]Maxim and Increasing Subsequence——树状数组+DP

    题目链接: Codeforces261D 题目大意:$k$次询问,每次给出一个长度为$n$的序列$b$及$b$中的最大值$maxb$,构造出序列$a$为$t$个序列$b$连接而成,求$a$的最长上升子 ...

  3. CF597C Subsequences 树状数组 + 动态规划

    设$f(i, j)$表示以$i$结尾的,长为$j$的上升子序列的数量 转移时用树状数组维护即可 复杂度为$O(kn \log n)$ 注:特判0 #include <cstdio> #in ...

  4. 【BZOJ】1818: [Cqoi2010]内部白点(树状数组+离散+特殊的技巧)

    http://www.lydsy.com/JudgeOnline/problem.php?id=1818 这一题一开始我就看错了,bzoj的那个绝对值109简直坑人,应该是10^9,我直接写了个暴力. ...

  5. HDU-4605 Magic Ball Game 树状数组+离散+dfs

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4605 题意:给一颗树,每个节点有个权值w[u],每个节点只有两个儿子或者没有儿子,从根节点放下一个小球 ...

  6. bzoj 5055: 膜法师 树状数组+离散

    先枚举每一个数,看它前面有几个比它小,算一下和为sum1,后面有几个比它大,算一下和为sum2,对答案的贡献为A[i]*sum1*sum2. 离散化后,树状数组就可以了. 就是倒着一边,顺着一边,统计 ...

  7. Codeforces Testing Round #12 C. Subsequences 树状数组

    C. Subsequences     For the given sequence with n different elements find the number of increasing s ...

  8. Codeforces Testing Round #12 C. Subsequences 树状数组维护DP

    C. Subsequences Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/contest/597/probl ...

  9. hdu_5877_Weak Pair(离散+DFS+树状数组)

    题目链接:hdu_5877_Weak Pair 题意: 给你一棵树,让你找有多少对满足那两个条件的weak pair 题解: 有人用Treap,我不会,然后我用树状数组+离散来替代Treap,用DFS ...

随机推荐

  1. 使用 letter-space 后文字不能居中解决

    letter-space:2em; text-align: center; 使用letter-space后和上面的字体对比明显没有居中: 选定元素后发现,每个字后面都被加了2em,不是不能居中而是因为 ...

  2. 团队协作第八周个人PSP

    11.3 --11.9本周例行报告 1.PSP(personal software process )个人软件过程. 类型 任务 开始时间                结束时间 中断时间 实际用时 ...

  3. python执行linux命令的两种方法

    python执行linux命令有两种方法: 在此以Linux常用的ls命令为例: 方法一:使用os模块 1 2 3 shell# python >> import os >> ...

  4. Calculator Part Ⅰ (代码规范化修改)

    GitHub/object-oriented 本次参照的C++代码规范 有一些规范内容在文件中其实并未提及,比如:空格的使用,修改的时候真的是一头雾水--根据文件中的例子,发现了一些文字部分没有提到的 ...

  5. python爬虫从入门到放弃(五)之 正则的基本使用(转)

    什么是正则表达式 正则表达式是对字符串操作的一种逻辑公式,就是 事先定义好的一些特定字符.及这些特定字符的组合,组成一个“规则字符”,这个“规则字符” 来表达对字符的一种过滤逻辑. 正则并不是pyth ...

  6. 检测固定IP的端口是否开放批出

    因为运维工作经常需要telnet某个IP的端口是否正常,因此有了下文 .BAT内容如下: @echo off for /f %%i in ('type ip.txt') do ( echo %%i t ...

  7. netbeans调试配置

    apache端口8050,xdebug端口9000 1.把项目放到apache的htdocs下(一定要放在htdocs上,要么调试的时候xdebug会一直卡在“等待连接中”) 2.把php_xdebu ...

  8. isset、is_null、empty的区别

    版本:PHP 5.4 1.isset() :检测变量是否存在,测试如下: $a = false; $b = null; $c; $d = 0; $e = true; var_dump(isset($a ...

  9. tomcat 相关

    servlet.xml 文件: 1 . 修改端口号,找到如下标签,port 属性就是端口号,修改之后重启服务器即可, <Connector connectionTimeout="200 ...

  10. [计算机网络-应用层] HTTP协议

    1.HTTP概况 Web的应用层协议是超文本传输协议(HTTP),它是Web的核心. HTTP由两部分程序实现:一个客户机程序和一个服务器程序,它们运行在不同的端系统中,通过交换HTTP报文进行对话. ...