题意:给有三种操作,一种是 1 k d,把第 k 个数加d,第二种是2 l r,查询区间 l, r的和,第三种是 3 l r,把区间 l,r 的所有数都变成离它最近的Fib数,

并且是最小的那个。

析:觉得应该是线段树的,但是。。。不会啊。。。就想胡搞一下。

所以用了树状数组,也就是和的,然后用一个set来维护每个不是Fibnoccia的数,然后再进行计算。

代码如下:

  1. #pragma comment(linker, "/STACK:1024000000,1024000000")
  2. #include <cstdio>
  3. #include <string>
  4. #include <cstdlib>
  5. #include <cmath>
  6. #include <iostream>
  7. #include <cstring>
  8. #include <set>
  9. #include <queue>
  10. #include <algorithm>
  11. #include <vector>
  12. #include <map>
  13. #include <cctype>
  14. #include <cmath>
  15. #include <stack>
  16. //#include <tr1/unordered_map>
  17. #define freopenr freopen("in.txt", "r", stdin)
  18. #define freopenw freopen("out.txt", "w", stdout)
  19. using namespace std;
  20. //using namespace std :: tr1;
  21.  
  22. typedef long long LL;
  23. typedef pair<int, int> P;
  24. const int INF = 0x3f3f3f3f;
  25. const double inf = 0x3f3f3f3f3f3f;
  26. const LL LNF = 0x3f3f3f3f3f3f;
  27. const double PI = acos(-1.0);
  28. const double eps = 1e-8;
  29. const int maxn = 1e5 + 5;
  30. const LL mod = 10000000000007;
  31. const int N = 1e6 + 5;
  32. const int dr[] = {-1, 0, 1, 0, 1, 1, -1, -1};
  33. const int dc[] = {0, 1, 0, -1, 1, -1, 1, -1};
  34. const int hr[]= {-2, -2, -1, -1, 1, 1, 2, 2};
  35. const int hc[]= {-1, 1, -2, 2, -2, 2, -1, 1};
  36. const char *Hex[] = {"0000", "0001", "0010", "0011", "0100", "0101", "0110", "0111", "1000", "1001", "1010", "1011", "1100", "1101", "1110", "1111"};
  37. inline LL gcd(LL a, LL b){ return b == 0 ? a : gcd(b, a%b); }
  38. int n, m;
  39. const int mon[] = {0, 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31};
  40. const int monn[] = {0, 31, 29, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31};
  41. inline int Min(int a, int b){ return a < b ? a : b; }
  42. inline int Max(int a, int b){ return a > b ? a : b; }
  43. inline LL Min(LL a, LL b){ return a < b ? a : b; }
  44. inline LL Max(LL a, LL b){ return a > b ? a : b; }
  45. inline bool is_in(int r, int c){
  46. return r >= 0 && r < n && c >= 0 && c < m;
  47. }
  48. LL sum1[maxn<<1], a[maxn];
  49. LL F[150];
  50. int cnt;
  51. set<int> sets;
  52. set<int> :: iterator it;
  53. int lowbit(int x){ return x & (-x); }
  54.  
  55. void add1(int x, LL d){
  56. while(x <= n){
  57. sum1[x] += d;
  58. x += lowbit(x);
  59. }
  60. }
  61.  
  62. LL qurey1(int x){
  63. LL ans = 0;
  64. while(x > 0){
  65. ans += sum1[x];
  66. x -= lowbit(x);
  67. }
  68. return ans;
  69. }
  70.  
  71. void solve(int l, int r){
  72. it = sets.lower_bound(l);
  73. while(it != sets.end() && *it <= r){
  74. LL *tmp = lower_bound(F+1, F+cnt, a[*it]);
  75. if(a[*it] == *tmp){ sets.erase(it++); continue; }
  76. LL *tmpp = tmp - 1;
  77. if(*tmp - a[*it] >= a[*it] - *tmpp){
  78. add1(*it, *tmpp - a[*it]);
  79. a[*it] = *tmpp;
  80. sets.erase(it++);
  81. }
  82. else{
  83. add1(*it, *tmp - a[*it]);
  84. a[*it] = *tmp;
  85. sets.erase(it++);
  86. }
  87. }
  88. }
  89. int main(){
  90. F[0] = F[1] = 1;
  91. cnt = 2;
  92. while(1){
  93. F[cnt] = F[cnt-1] + F[cnt-2];
  94. if(F[cnt] > (1LL<<61)) break;
  95. ++cnt;
  96. }
  97. ++cnt;
  98. while(scanf("%d %d", &n, &m) == 2){
  99. sets.clear();
  100. for(int i = 0; i <= n; ++i){
  101. sum1[i] = a[i] = 0;
  102. sets.insert(i);
  103. }
  104. int l, r, x;
  105. for(int i = 0; i < m; ++i){
  106. scanf("%d", &x);
  107. if(1 == x){
  108. scanf("%d %d", &l, &r);
  109. a[l] += r;
  110. sets.insert(l);
  111. add1(l, (LL)r);
  112. }
  113. else if(2 == x){
  114. scanf("%d %d", &l, &r);
  115. printf("%I64d\n", qurey1(r) - qurey1(l-1));
  116. }
  117. else if(3 == x){
  118. scanf("%d %d", &l, &r);
  119. solve(l, r);
  120. }
  121. }
  122. }
  123. return 0;
  124. }

HDU 4893 Wow! Such Sequence! (树状数组)的更多相关文章

  1. HDU 5057 Argestes and Sequence --树状数组(卡内存)

    题意:给n个数字,每次两种操作: 1.修改第x个数字为y. 2.查询[L,R]区间内第D位为P的数有多少个. 解法:这题当时被卡内存了,后来看了下别人代码发现可以用unsigned short神奇卡过 ...

  2. HDU 5862 Counting Intersections(离散化+树状数组)

    HDU 5862 Counting Intersections(离散化+树状数组) 题目链接http://acm.split.hdu.edu.cn/showproblem.php?pid=5862 D ...

  3. hdu 5517 Triple(二维树状数组)

    Triple Time Limit: 12000/6000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)Total Sub ...

  4. hdu 4893 Wow! Such Sequence!(线段树)

    题目链接:hdu 4983 Wow! Such Sequence! 题目大意:就是三种操作 1 k d, 改动k的为值添加d 2 l r, 查询l到r的区间和 3 l r. 间l到r区间上的所以数变成 ...

  5. HDU 6078 Wavel Sequence 树状数组优化DP

    Wavel Sequence Problem Description Have you ever seen the wave? It's a wonderful view of nature. Lit ...

  6. HDU 1394 Minimum Inversion Number ( 树状数组求逆序数 )

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1394 Minimum Inversion Number                         ...

  7. HDU 2689 Sort it【树状数组】

    Sort it Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Sub ...

  8. HDU 5862 Counting Intersections (树状数组)

    Counting Intersections 题目链接: http://acm.split.hdu.edu.cn/showproblem.php?pid=5862 Description Given ...

  9. hdu 5592 ZYB's Game 树状数组

    ZYB's Game Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://acm.hdu.edu.cn/showproblem.php?pid=55 ...

随机推荐

  1. Codeforces936C. Lock Puzzle

    给个串,只能用操作shift x表示把后面x个字符翻转后放到串的前面.问s串怎么操作能变t串.n<=2000,操作次数<=6100. 打VP时这转来转去的有点晕... 可以想一种逐步构造的 ...

  2. 汕头市赛srm8 C-3

    n<=100000个点m<=300000条边有权无向联通图,给出K<=10000个特殊点求K个点中任意两点最短路的最小值. 方法一:K小,随便搞.先构造最短路树,在最短路树上Dijk ...

  3. APP后端处理视频的方案

    在当前的app应用中,到处都能看到视频的身影,例如,在社交类的app上,用户可以拍摄属于自己的小视频,并发布到相应得栏目,增加和好友们互动的机会. 后台常见的视频处理有以下几种: ·          ...

  4. 洛谷—— P1656 炸铁路

    P1656 炸铁路 题目描述 因为某国被某红色政权残酷的高压暴力统治.美国派出将军uim,对该国进行战略性措施,以解救涂炭的生灵. 该国有n个城市,这些城市以铁路相连.任意两个城市都可以通过铁路直接或 ...

  5. ZOJ 3471 【状态压缩DP】

    题意: 有n种化学物质,他们彼此反应会有一种消失并释放出能量. 给出矩阵,第i行j列代表i和j反应j消失释放的能量. 求最大释放多少能量. 思路: 状态压缩DP,我是这么想的. 利用二进制0代表该物质 ...

  6. Spring Boot使用HandlerInterceptorAdapter和WebMvcConfigurerAdapter实现原始的登录验证

    HandlerInterceptorAdapter的介绍:http://www.cnblogs.com/EasonJim/p/7704740.html,相当于一个Filter拦截器,但是这个颗粒度更细 ...

  7. html5 拖拽元素

    利用html5实现元素的拖拽,让拖动元素在指定的容器中拖动. 注意点:1.被拖元素要设置拖动属性.draggable="true" 2.容器元素要设置阻止默认事件处理 实现效果图如 ...

  8. easyshell 安装

    EasyShell是一个可以直接在Eclipse IDE中打开shell窗口的工具,在shell中运行选中的文件,打资源管理. 百度经验:jingyan.baidu.com 工具/原料 Easy_Sh ...

  9. Go---设计模式(策略模式)

    策略模式定义了算法家族,在调用算法家族的时候不感知算法的变化,客户也不会受到影响. 下面用<大话设计模式>中的一个实例进行改写. 例:超市中经常进行促销活动,促销活动的促销方法就是一个个策 ...

  10. 【APUE】关于信号的一些常用函数

    kill和raise函数 #include <signal.h> int kill(pid_t pid,int signo); int raise(int signo);//两个函数返回值 ...