【bzoj4378】[POI2015]Logistyka 离散化+树状数组
题目描述
维护一个长度为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个树状数组。
结构体能够大大减少代码量~
- #include <cstdio>
- #include <algorithm>
- #define N 1000010
- using namespace std;
- typedef long long ll;
- int m , x[N] , opt[N] , top;
- ll y[N] , v[N] , w[N];
- char str[5];
- struct data
- {
- ll f[N];
- void update(int x , int a)
- {
- int i;
- for(i = x ; i <= m + 1 ; i += i & -i) f[i] += a;
- }
- ll query(int x)
- {
- int i;
- ll ans = 0;
- for(i = x ; i ; i -= i & -i) ans += f[i];
- return ans;
- }
- }num , sum;
- int main()
- {
- int n , i , tmp;
- scanf("%d%d" , &n , &m);
- v[0] = 1;
- 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');
- sort(v , v + m + 1);
- for(i = 1 ; i <= n ; i ++ ) num.update(1 , 1) , w[i] = 1;
- for(i = 1 ; i <= m ; i ++ )
- {
- tmp = lower_bound(v , v + m + 1 , y[i]) - v + 1;
- if(opt[i]) printf("%s\n" , (n - num.query(tmp)) * (y[i] - 1) + sum.query(tmp) >= x[i] * (y[i] - 1) ? "TAK" : "NIE");
- 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];
- }
- return 0;
- }
【bzoj4378】[POI2015]Logistyka 离散化+树状数组的更多相关文章
- CodeForces 540E - Infinite Inversions(离散化+树状数组)
花了近5个小时,改的乱七八糟,终于A了. 一个无限数列,1,2,3,4,...,n....,给n个数对<i,j>把数列的i,j两个元素做交换.求交换后数列的逆序对数. 很容易想到离散化+树 ...
- Ultra-QuickSort(归并排序+离散化树状数组)
Ultra-QuickSort Time Limit: 7000MS Memory Limit: 65536K Total Submissions: 50517 Accepted: 18534 ...
- HDU 5862 Counting Intersections(离散化+树状数组)
HDU 5862 Counting Intersections(离散化+树状数组) 题目链接http://acm.split.hdu.edu.cn/showproblem.php?pid=5862 D ...
- BZOJ_4627_[BeiJing2016]回转寿司_离散化+树状数组
BZOJ_4627_[BeiJing2016]回转寿司_离散化+树状数组 Description 酷爱日料的小Z经常光顾学校东门外的回转寿司店.在这里,一盘盘寿司通过传送带依次呈现在小Z眼前.不同的寿 ...
- poj-----Ultra-QuickSort(离散化+树状数组)
Ultra-QuickSort Time Limit: 7000MS Memory Limit: 65536K Total Submissions: 38258 Accepted: 13784 ...
- Code Forces 652D Nested Segments(离散化+树状数组)
Nested Segments time limit per test 2 seconds memory limit per test 256 megabytes input standard in ...
- hdu 3015 Disharmony Trees (离散化+树状数组)
Disharmony Trees Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) ...
- 【bzoj4627】[BeiJing2016]回转寿司 离散化+树状数组
题目描述 给出一个长度为n的序列,求所有元素的和在[L,R]范围内的连续子序列的个数. 输入 第一行包含三个整数N,L和R,分别表示寿司盘数,满意度的下限和上限. 第二行包含N个整数Ai,表示小Z对寿 ...
- HDU 6318.Swaps and Inversions-求逆序对-线段树 or 归并排序 or 离散化+树状数组 (2018 Multi-University Training Contest 2 1010)
6318.Swaps and Inversions 这个题就是找逆序对,然后逆序对数*min(x,y)就可以了. 官方题解:注意到逆序对=交换相邻需要交换的次数,那么输出 逆序对个数 即可. 求逆序对 ...
随机推荐
- JQuery 解决按钮上的倒计时问题
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/ ...
- 谷歌angle库使用心得
通过谷歌的angle库可以在项目中,调用opengl接口渲染时,选择调用directx或者webgl来渲染,避免机器没有安装opengl驱动启动异常的问题. 这个库的使用可以不修改原有使用opengl ...
- Session和cookic
session是无状态的方式,服务器存储机制,当用户第一次请求服务器,服务器会给客户分配一个标识id,客户端再次访问服务器,根据session id 去访问服务器数据库,返回信息,同时session ...
- 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 ...
- tomcat8080端口占用解决办法
打开控制台,在窗口中输入指令:netstat -ano | findstr 8080 指令的意思是找出占用8080端口的进程pid 上图中表示占用进程pid为23288,然后再次输入指令: ...
- ethereum(以太坊)(九)--global(全局函数)
pragma solidity ^0.4.0; contract modifierTest{ bytes32 public blockhash; address public coinbase; ui ...
- float 浮动详解
浮动(float):浮动原先设定时主要是用于文本环绕图像设定的,后来发现其在css布局中有很大的帮助,故渐渐使用浮动. 浮动后的元素脱离了文档的普通流,使得浮动的元素不占据文档的位置,其他元素可以覆盖 ...
- mysql sum 为 0 的解决方法
使用SQL语句SUM函数的时候,默认查询没有值的情况下返回的是null,而实际可能我们要用的是返回0. 解决方法:SELECT SUM(count) FROM test_table 改成: SELEC ...
- 中国剩余定理算法详解 + POJ 1006 Biorhythms 生理周期
转载请注明出处:http://exp-blog.com/2018/06/24/pid-1054/ #include <iostream> #include <cstdio> u ...
- 笔记-git-git服务器安装及配置
笔记-git-git服务器安装及配置 1. GIT服务器简介 Git 可以使用四种主要的协议来传输数据:本地传输,SSH 协议,Git 协议和 HTTP 协议.下面分别介绍一下哪些情形应该使 ...