题目描述

维护一个长度为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
  对于每次询问,设大于等于s的数有k个,那么如果剩下数的和sum>=(c-k)*s,剩下数中每次取最大的(c-k)个就一定能进行s次(证明在最后)。只要离散化一下之后用树状数组维护一下区间个数及区间和就好了。
证明:
首先大于等于s的k个数一定能取s次,设p=c-k,如果取了z次后取不了了,也就是剩下的数不足p个,因为剩下的数之和一定>=p*(s-z),那么剩下的数之中一定有大于s-z的,在取z次之前这个数就大于s了,与上面矛盾,因此只要sum>=p*s就一定能进行s次,反之因为和都小于s,就一定取不了s次。
  1. #include<set>
  2. #include<map>
  3. #include<queue>
  4. #include<cmath>
  5. #include<stack>
  6. #include<vector>
  7. #include<cstdio>
  8. #include<cstring>
  9. #include<iostream>
  10. #include<algorithm>
  11. using namespace std;
  12. int n,m;
  13. int cnt;
  14. char s[20];
  15. int a[1000010];
  16. int b[1000010];
  17. int c[1000010];
  18. int d[1000010];
  19. int e[1000010];
  20. int h[1000010];
  21. struct node
  22. {
  23. long long v[1000010];
  24. void add(int x,int t)
  25. {
  26. for(;x<=cnt;x+=x&-x)
  27. {
  28. v[x]+=t;
  29. }
  30. }
  31. long long query(int x)
  32. {
  33. long long res=0;
  34. for(;x;x-=x&-x)
  35. {
  36. res+=v[x];
  37. }
  38. return res;
  39. }
  40. }b1,b2;
  41. int find(int x)
  42. {
  43. int l=1,r=cnt,mid;
  44. while(l<r)
  45. {
  46. mid=(l+r)>>1;
  47. if(h[mid]<x)
  48. {
  49. l=mid+1;
  50. }
  51. else
  52. {
  53. r=mid;
  54. }
  55. }
  56. return l;
  57. }
  58. int main()
  59. {
  60. int num;
  61. scanf("%d%d",&n,&m);
  62. for(int i=1;i<=m;i++)
  63. {
  64. scanf("%s",s);
  65. scanf("%d%d",&b[i],&c[i]);
  66. e[i]=c[i];
  67. if(s[0]=='U')
  68. {
  69. d[i]=1;
  70. }
  71. }
  72. sort(e+1,e+m+1);
  73. h[++cnt]=e[1];
  74. for(int i=2;i<=m;i++)
  75. {
  76. if(e[i]!=e[i-1])
  77. {
  78. h[++cnt]=e[i];
  79. }
  80. }
  81. for(int i=1;i<=m;i++)
  82. {
  83. c[i]=find(c[i]);
  84. }
  85. for(int i=1;i<=m;i++)
  86. {
  87. if(d[i])
  88. {
  89. if(num=a[b[i]])
  90. {
  91. b1.add(num,-1);
  92. b2.add(num,-h[num]);
  93. }
  94. a[b[i]]=c[i];
  95. b1.add(c[i],1);
  96. b2.add(c[i],h[c[i]]);
  97. }
  98. else
  99. {
  100. b2.query(c[i]-1)>=(b[i]-b1.query(cnt)+b1.query(c[i]-1))*h[c[i]]?printf("TAK\n"):printf("NIE\n");
  101. }
  102. }
  103. }

BZOJ4378[POI2015]Logistyka——树状数组的更多相关文章

  1. 【BZOJ4378】[POI2015]Logistyka 树状数组

    [BZOJ4378][POI2015]Logistyka Description 维护一个长度为n的序列,一开始都是0,支持以下两种操作:1.U k a 将序列中第k个数修改为a.2.Z c s 在这 ...

  2. BZOJ_4378_[POI2015]Logistyka_树状数组

    BZOJ_4378_[POI2015]Logistyka_树状数组 Description 维护一个长度为n的序列,一开始都是0,支持以下两种操作: 1.U k a 将序列中第k个数修改为a. 2.Z ...

  3. 【bzoj4378】[POI2015]Logistyka 离散化+树状数组

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

  4. [POI2015]LOG(树状数组)

    今天考试考了这题,所以来贡献\([POI2015]LOG\)的第一篇题解.代码略丑,调了快三个小时才调出来\(AC\)代码. 对于这种小清新数据结构题,所以我觉得树状数组才是这道题的正确打开方式. 首 ...

  5. 【BZOJ4382】[POI2015]Podział naszyjnika 堆+并查集+树状数组

    [BZOJ4382][POI2015]Podział naszyjnika Description 长度为n的一串项链,每颗珠子是k种颜色之一. 第i颗与第i-1,i+1颗珠子相邻,第n颗与第1颗也相 ...

  6. 【BZOJ4384】[POI2015]Trzy wieże 树状数组

    [BZOJ4384][POI2015]Trzy wieże Description 给定一个长度为n的仅包含'B'.'C'.'S'三种字符的字符串,请找到最长的一段连续子串,使得这一段要么只有一种字符 ...

  7. 树状数组【洛谷P3586】 [POI2015]LOG

    P3586 [POI2015]LOG 维护一个长度为n的序列,一开始都是0,支持以下两种操作:1.U k a 将序列中第k个数修改为a.2.Z c s 在这个序列上,每次选出c个正数,并将它们都减去1 ...

  8. BZOJ 1103: [POI2007]大都市meg [DFS序 树状数组]

    1103: [POI2007]大都市meg Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 2221  Solved: 1179[Submit][Sta ...

  9. bzoj1878--离线+树状数组

    这题在线做很麻烦,所以我们选择离线. 首先预处理出数组next[i]表示i这个位置的颜色下一次出现的位置. 然后对与每种颜色第一次出现的位置x,将a[x]++. 将每个询问按左端点排序,再从左往右扫, ...

随机推荐

  1. php利用自定义key,对数据加解密的方法

    客户端和服务端通信时,有个场景很常见,通过一个id作为url参数来回传递.假设现在业务上只有这个id标识,那么需要稍微安全一点的通信,对这个id进行加密传输,到服务端再进行解密.这里需要一个服务端进行 ...

  2. SessionState in ASP.NET Core(转载)

    问: In asp.net mvc we used to decorate controller for disabling session state by using attribute as [ ...

  3. BZOJ4237 JOISC2014 稻草人 CDQ分治、单调栈

    传送门 题意:给出平面上$N$个点,求满足以下两个条件的矩形:①左下角与右上角各有一个点:②矩形内部没有点.$N \leq 2 \times 10^5$,所有数字大于等于$0$,保证坐标两两不同 最开 ...

  4. 关于小程序登录时获取openId和unionId走过的坑

    目前的项目是在做小程序这方面的,接触过的人应该都知道,同一个微信开放平台下的相同主体的App.公众号.小程序的unionid是相同的,这样就可以锁定是不是同一个用户.微信针对不同的用户在不同的应用下都 ...

  5. [Oracle]OWI学习笔记--001

    [Oracle]OWI学习笔记--001 在 OWI 的概念里面,最为重要的是 等待事件 和 等待时间. 等待事件发生时,需要通过 P1,P2,P3 查看具体的资源. 可以通过 v$session_w ...

  6. for循环两个略骚的写法

    骚写法 或许你知道,总之我觉得很酷,希望你也这么认为. 递增遍历 最常见场景,从 0 到 10 的遍历,不输出 10: for(let i = -1; ++i < 10;) { console. ...

  7. 记一次yarn导致cpu飙高的异常排查经历

    yarn就先不介绍了,这次排坑经历还是有收获的,从日志到堆栈信息再到源码,很有意思,下面听我说 问题描述: 集群一台NodeManager的cpu负载飙高. 进程还在但是看日志已经不再向Resourc ...

  8. [T-ARA N4/二段横踢][Can We Love]

    歌词来源:http://music.163.com/#/song?id=26310867 Can We Love Can We Love [Can We Love Can We Love] Can W ...

  9. Spring AOP不起作用原因

    一.直接在切面类定义切点: AOP切面类里面的方法全部不支持触发切面,否则一个切面函数把自己当做切点就会导致递归层层调用. AOP切面类发出函数调用一律不触发切面,避免两个切面类相互调用迭代请求的情况 ...

  10. VMware vSphere虚拟化-VMware ESXi 5.5组件安装过程记录

    几种主要的虚拟化 ESXi是VMware公司研发的虚拟机服务器,ESXi已经实现了与Virtual Appliance Marketplace的直接整合,使用户能够即刻下载并运行虚拟设备.这为 即插即 ...