题目描述

维护一个长度为n的序列,一开始都是0,支持以下两种操作:
1.U k a 将序列中第k个数修改为a。
2.Z c s 在这个序列上,每次选出c个正数,并将它们都减去1,询问能否进行s次操作。
每次询问独立,即每次询问不会对序列进行修改。

输入

第一行包含两个正整数n,m(1<=n,m<=1000000),分别表示序列长度和操作次数。
接下来m行为m个操作,其中1<=k,c<=n,0<=a<=10^9,1<=s<=10^9。

输出

包含若干行,对于每个Z询问,若可行,输出TAK,否则输出NIE。

样例输入

3 8
U 1 5
U 2 7
Z 2 6
U 3 1
Z 2 6
U 2 2
Z 2 6
Z 2 1

样例输出

NIE
TAK
NIE
TAK


题解

离散化+树状数组

刚开始看错题意了,以为是在某个选定的区间中查询,想了一大堆离线算法发现还是搞不出来,然后才注意到是查询整个序列。。

每次选出c个正数,并将它们都减去1,能进行s次操作的充分必要条件是:

因为每个数最多只能被选min(w[i],s)次。

这个式子可以用树状数组快速求出,方法为离散化后求出小于等于s的数的和以及个数,再用n减去个数即为大于s的个数。这里使用了2个树状数组。

结构体能够大大减少代码量~

  1. #include <cstdio>
  2. #include <algorithm>
  3. #define N 1000010
  4. using namespace std;
  5. typedef long long ll;
  6. int m , x[N] , opt[N] , top;
  7. ll y[N] , v[N] , w[N];
  8. char str[5];
  9. struct data
  10. {
  11. ll f[N];
  12. void update(int x , int a)
  13. {
  14. int i;
  15. for(i = x ; i <= m + 1 ; i += i & -i) f[i] += a;
  16. }
  17. ll query(int x)
  18. {
  19. int i;
  20. ll ans = 0;
  21. for(i = x ; i ; i -= i & -i) ans += f[i];
  22. return ans;
  23. }
  24. }num , sum;
  25. int main()
  26. {
  27. int n , i , tmp;
  28. scanf("%d%d" , &n , &m);
  29. v[0] = 1;
  30. for(i = 1 ; i <= m ; i ++ ) scanf("%s%d%lld" , str , &x[i] , &y[i]) , y[i] ++ , v[i] = y[i] , opt[i] = (str[0] == 'Z');
  31. sort(v , v + m + 1);
  32. for(i = 1 ; i <= n ; i ++ ) num.update(1 , 1) , w[i] = 1;
  33. for(i = 1 ; i <= m ; i ++ )
  34. {
  35. tmp = lower_bound(v , v + m + 1 , y[i]) - v + 1;
  36. if(opt[i]) printf("%s\n" , (n - num.query(tmp)) * (y[i] - 1) + sum.query(tmp) >= x[i] * (y[i] - 1) ? "TAK" : "NIE");
  37. else num.update(lower_bound(v , v + m + 1 , w[x[i]]) - v + 1 , -1) , sum.update(lower_bound(v , v + m + 1 , w[x[i]]) - v + 1 , 1 - w[x[i]]) , num.update(tmp , 1) , sum.update(tmp , y[i] - 1) , w[x[i]] = y[i];
  38. }
  39. return 0;
  40. }

【bzoj4378】[POI2015]Logistyka 离散化+树状数组的更多相关文章

  1. CodeForces 540E - Infinite Inversions(离散化+树状数组)

    花了近5个小时,改的乱七八糟,终于A了. 一个无限数列,1,2,3,4,...,n....,给n个数对<i,j>把数列的i,j两个元素做交换.求交换后数列的逆序对数. 很容易想到离散化+树 ...

  2. Ultra-QuickSort(归并排序+离散化树状数组)

    Ultra-QuickSort Time Limit: 7000MS   Memory Limit: 65536K Total Submissions: 50517   Accepted: 18534 ...

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

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

  4. BZOJ_4627_[BeiJing2016]回转寿司_离散化+树状数组

    BZOJ_4627_[BeiJing2016]回转寿司_离散化+树状数组 Description 酷爱日料的小Z经常光顾学校东门外的回转寿司店.在这里,一盘盘寿司通过传送带依次呈现在小Z眼前.不同的寿 ...

  5. poj-----Ultra-QuickSort(离散化+树状数组)

    Ultra-QuickSort Time Limit: 7000MS   Memory Limit: 65536K Total Submissions: 38258   Accepted: 13784 ...

  6. Code Forces 652D Nested Segments(离散化+树状数组)

     Nested Segments time limit per test 2 seconds memory limit per test 256 megabytes input standard in ...

  7. hdu 3015 Disharmony Trees (离散化+树状数组)

    Disharmony Trees Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) ...

  8. 【bzoj4627】[BeiJing2016]回转寿司 离散化+树状数组

    题目描述 给出一个长度为n的序列,求所有元素的和在[L,R]范围内的连续子序列的个数. 输入 第一行包含三个整数N,L和R,分别表示寿司盘数,满意度的下限和上限. 第二行包含N个整数Ai,表示小Z对寿 ...

  9. HDU 6318.Swaps and Inversions-求逆序对-线段树 or 归并排序 or 离散化+树状数组 (2018 Multi-University Training Contest 2 1010)

    6318.Swaps and Inversions 这个题就是找逆序对,然后逆序对数*min(x,y)就可以了. 官方题解:注意到逆序对=交换相邻需要交换的次数,那么输出 逆序对个数 即可. 求逆序对 ...

随机推荐

  1. JQuery 解决按钮上的倒计时问题

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

  2. 谷歌angle库使用心得

    通过谷歌的angle库可以在项目中,调用opengl接口渲染时,选择调用directx或者webgl来渲染,避免机器没有安装opengl驱动启动异常的问题. 这个库的使用可以不修改原有使用opengl ...

  3. Session和cookic

    session是无状态的方式,服务器存储机制,当用户第一次请求服务器,服务器会给客户分配一个标识id,客户端再次访问服务器,根据session id 去访问服务器数据库,返回信息,同时session ...

  4. LeetCode426.Convert Binary Search Tree to Sorted Doubly Linked List

    题目 Convert a BST to a sorted circular doubly-linked list in-place. Think of the left and right point ...

  5. tomcat8080端口占用解决办法

    打开控制台,在窗口中输入指令:netstat -ano | findstr 8080       指令的意思是找出占用8080端口的进程pid 上图中表示占用进程pid为23288,然后再次输入指令: ...

  6. ethereum(以太坊)(九)--global(全局函数)

    pragma solidity ^0.4.0; contract modifierTest{ bytes32 public blockhash; address public coinbase; ui ...

  7. float 浮动详解

    浮动(float):浮动原先设定时主要是用于文本环绕图像设定的,后来发现其在css布局中有很大的帮助,故渐渐使用浮动. 浮动后的元素脱离了文档的普通流,使得浮动的元素不占据文档的位置,其他元素可以覆盖 ...

  8. mysql sum 为 0 的解决方法

    使用SQL语句SUM函数的时候,默认查询没有值的情况下返回的是null,而实际可能我们要用的是返回0. 解决方法:SELECT SUM(count) FROM test_table 改成: SELEC ...

  9. 中国剩余定理算法详解 + POJ 1006 Biorhythms 生理周期

    转载请注明出处:http://exp-blog.com/2018/06/24/pid-1054/ #include <iostream> #include <cstdio> u ...

  10. 笔记-git-git服务器安装及配置

    笔记-git-git服务器安装及配置 1.      GIT服务器简介 Git 可以使用四种主要的协议来传输数据:本地传输,SSH 协议,Git 协议和 HTTP 协议.下面分别介绍一下哪些情形应该使 ...