多校联赛7 1001 hdu 4666(最远哈曼顿距离+优先队列)
吐个糟,尼玛今天被虐成狗了,一题都没搞出来,这题搞了N久居然还是搞不出来,一直TLE,最后还是参考别人代码才领悟的,思路就这么简单,
就是不会转弯,看着模板却不会改,艹,真怀疑自己是不是个笨蛋
题意:求n维空间的最远哈曼顿距离。给出n和k,下面n个操作,0表示添加一个k维空间的点,然后给出该点坐标,1 x表示删除第x个操作给出的点
,对于每个操作都输出最远哈曼顿距离,n《=60000,k《=5。
分析:最远曼哈顿距离的模板是直接求D维空间n个点的,复杂度是O(n*2^D),而该题要求每次加一个点就求一次最远曼哈顿距离,如果直接套模板
的话复杂度是O(n^2*2^D),这已经相当高了,再加上有删点操作,所以肯定是TLE的,我刚开始就是这么做的,应该要进行优化。
其实我们可以用堆或优先队列来优化,根据最远曼哈顿距离的求法(不懂得可以百度),其实就是找出每个点去绝对值后的形式,然后枚举所有的
组合再求出最大值,所以我们可以建立一个最小堆和最大堆,每加入一个点就枚举该点去绝对值后的形式(总共有2^D-1种),将其加入到对应的
两个堆中,将最大堆和最小堆堆顶元素相减,其实就是两点之间的曼哈顿距离了,最后枚举所有的形式,找最大值就行了。
对于删点操作,用一个数组p[]标记一下,在枚举形式求最大值时,判断一下堆顶元素是否是已被删的点,如果是的话,出堆就行了
还有就是求距离的时候不要像模板那样用二维数组,不然会爆内存的,我就是这样MLE了两次 =_=||
代码如下:
#include<stdio.h>
#include<vector>
#include<string.h>
#include<queue>
using namespace std;
int coe[],minx[][],maxx[][],pt[];
int p[];
int minp,maxp,ans,m;
struct node1{
int s,i;
bool operator <(const node1 &a)const{
return s<a.s;
}
};
struct node2{
int s,i;
bool operator<(const node2 &a)const{
return s>a.s;
}
};
priority_queue<node1> q1[];
priority_queue<node2> q2[];
node1 x;
node2 y;
void GetD(int D){
int s,i,dis,tot=(<<D);
for(s=;s<tot;s++)
{
for(i=;i<D;i++)
if(s&(<<i))
coe[i]=-;
else
coe[i]=;
dis=;
for(i=;i<D;i++)
dis=dis+coe[i]*pt[i];
x.s=dis;
x.i=m;
y.s=dis;
y.i=m;
q1[s].push(x);
q2[s].push(y);
}
}
void Solve(int D)
{
int s,tot=(<<D);
int tmp;
for(s=;s<tot;s++)
{
while(!p[q1[s].top().i]&&!q1[s].empty())
q1[s].pop();
while(!p[q2[s].top().i]&&!q2[s].empty())
q2[s].pop();
maxx[s][]=q1[s].top().s;
maxx[s][]=q1[s].top().i;
minx[s][]=q2[s].top().s;
minx[s][]=q2[s].top().i;
}
ans=;
for(s=;s<tot;s++)
{
tmp=maxx[s][]-minx[s][];
if(tmp>ans)
{
ans=tmp;
maxp=maxx[s][];
minp=minx[s][];
}
}
printf("%d\n",ans);
}
int main()
{
int s,tot,n,k,i,od,x,j;
while(scanf("%d%d",&n,&k)!=EOF)
{
memset(p,,sizeof(p));
minp=maxp=-;
tot=(<<k);
for(s=;s<tot;s++)
{
while(!q1[s].empty())
q1[s].pop();
while(!q2[s].empty())
q2[s].pop();
}
m=-;
for(i=;i<n;i++)
{
scanf("%d",&od);
m++;
if(od==)
{
p[i]=;
for(j=;j<k;j++)
scanf("%d",&pt[j]);
GetD(k);
Solve(k);
}
else
{
scanf("%d",&x);
p[x-]=;
if((x-)==minp||(x-)==maxp)
Solve(k);
else
printf("%d\n",ans);
}
}
}
return ;
}
多校联赛7 1001 hdu 4666(最远哈曼顿距离+优先队列)的更多相关文章
- HDU 4666 最远曼哈顿距离
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=4666 关于最远曼哈顿距离的介绍: http://blog.csdn.net/taozifish/ar ...
- 2015 HDU 多校联赛 5363 Key Set
2015 HDU 多校联赛 5363 Key Set 题目: http://acm.hdu.edu.cn/showproblem.php? pid=5363 依据前面给出的样例,得出求解公式 fn = ...
- 2015 HDU 多校联赛 5317 RGCDQ 筛法求解
2015 HDU 多校联赛 5317 RGCDQ 筛法求解 题目 http://acm.hdu.edu.cn/showproblem.php? pid=5317 本题的数据量非常大,測试样例多.数据 ...
- hdu 4666:Hyperspace(最远曼哈顿距离 + STL使用)
Hyperspace Time Limit: 20000/10000 MS (Java/Others) Memory Limit: 65535/65535 K (Java/Others)Tota ...
- 2019HDU多校第一场1001 BLANK (DP)(HDU6578)
2019HDU多校第一场1001 BLANK (DP) 题意:构造一个长度为n(n<=10)的序列,其中的值域为{0,1,2,3}存在m个限制条件,表示为 l r x意义为[L,R]区间里最多能 ...
- HDU 4666 Hyperspace (2013多校7 1001题 最远曼哈顿距离)
Hyperspace Time Limit: 20000/10000 MS (Java/Others) Memory Limit: 65535/65535 K (Java/Others)Tota ...
- 2014多校第五场1001 || HDU 4911 Inversion (归并求逆序数)
题目链接 题意 : 给你一个数列,可以随意交换两相邻元素,交换次数不超过k次,让你找出i < j 且ai > aj的(i,j)的对数最小是多少对. 思路 : 一开始想的很多,各种都想了,后 ...
- HDU 4627 The Unsolvable Problem 杭电多校联赛第三场1009 数学题
题意描述:给出一个n,要求在所有满足n = a+b的a和b里面求a和b的最小公倍数最大的两个数的最小公倍数. 解题报告:比赛的时候看到这个题的第一反应就是寻找这两个数一定是在a和b比较接近的地方找,这 ...
- HDU 4639 hehe 杭电2013多校联赛第四场1008题
解题报告:题目的意思是输入一个字符串,并规定,里面的“hehe”可以用"wqnmlgb"来代替,也可以不代替,问输入的这个字符串在经过相关的代替之后可以有多少种不同的形态.先打一个 ...
随机推荐
- 【TJOI2017】DNA
题面 题解 对字符串一脸懵的我肯定只能用$FFT$这种暴力方法水过啊... 将后面那个字符串翻转一下,对$\text{AGCT}$分别统计,用$FFT$就可以啦 代码 #include<cstd ...
- spring学习笔记 星球日one - xml方式配置bean
ide: idea lib包的导入:http://webcache.googleusercontent.com/search?q=cache:http://zyjustin9.iteye.com/bl ...
- Famous框架系列一:famous/core/Surface
famous/core/Surface 既然是Famous的第一篇文章,就先给Famous打个广告:http://periodic.famo.us Famous12年的作品,点击右下角Fun thi ...
- Python的进阶:copy与deepcopy区别
copy()与deepcopy()之间的区分必须要涉及到python对于数据的存储方式. 首先直接上结论: —–我们寻常意义的复制就是深复制,即将被复制对象完全再复制一遍作为独立的新个体单独存在.所以 ...
- 【PaPaPa】实现缓存决策 - 让你的缓存变的有智慧
我有话说 本来这一篇我打算放到后面再说,可是之前泄漏了一点关于缓存决策的代码后被好多人催更了. 在此感谢大家的支持,让我更有动力的写这个系列.你们的关注让我觉得我的决定是对的,我会坚持下去把这个项目做 ...
- css布局笔记(二)Flex
flex Flex是"Flexible Box"的缩写,意为"弹性布局",用来为盒状模型提供最大的灵活性. 任何一个容器都可指定为Flex布局. .box{di ...
- oracle数据库之子查询
子查询也叫内部查询,在主查询之前执行一次并得到结果,此结果一般情况下,是用来当做是主查询的条件. -- 在 emp 表中,找出工资比 ALLEN 的高? -- 先查出 ALLEN 的工资是多少? ...
- java 实现验证码功能
所需文件以及技术: · SecurityUtil.java (后面我会复制给大家) · 图像处理技术 · 向客户端输出io流 一,实现的原理,当视图页面加载的时候通过<img >元素的 ...
- [译文]c#扩展方法(Extension Method In C#)
原文链接: https://www.codeproject.com/Tips/709310/Extension-Method-In-Csharp 介绍 扩展方法是C# 3.0引入的新特性.扩展方法使你 ...
- Centos7.4简单安装使用gitlab+maven+jenkins实现java代码的持续集成部署
1.工具的简单介绍 gitlab--源代码版本管理控制工具 maven--java代码编译构建工具 jenkins--基于java开发的自动化持续集成部署工具 sonar--代码质量管理工具 2.gi ...