题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4666

#include <cstdio>
#include <cstring>
#include <iostream>
#include <cmath>
#include <queue>
#include <set>
using namespace std;
const int maxn = ; struct MaxHeap{
int d; //k维的各种加或减的和;
int p; //每个坐标和所属的标号
MaxHeap(int d=,int p=):d(d),p(p) {}
bool operator < (const MaxHeap& r) const{
return d < r.d;
}
};
struct MinHeap{
int d;
int p;
MinHeap(int d=,int p=):d(d),p(p) {}
bool operator < (const MinHeap& r) const{
return d > r.d;
}
};
priority_queue<MaxHeap> Max[]; //存储1<<k种坐标组合情况;
priority_queue<MinHeap> Min[];
int q,k;
bool del[maxn]; //标记别删除的点; int main()
{
//freopen("E:\\acm\\input.txt","r",stdin);
while(cin>>q>>k){
memset(del,,sizeof(del));
for(int i=;i<;i++){
while(!Max[i].empty()) Max[i].pop();
while(!Min[i].empty()) Min[i].pop();
}
int a[],od;
MaxHeap temp1; MinHeap temp2;
for(int m=;m<=q;m++){
scanf("%d",&od);
if(od == ){
for(int i=;i<k;i++) scanf("%d",&a[i]);
for(int i=;i<(<<k);i++){
int add = ;
for(int j=;j<k;j++)
if(<<j & i) add += a[j];
else add -= a[j];
temp1 = MaxHeap(add,m);
temp2 = MinHeap(add,m);
Max[i].push(temp1);
Min[i].push(temp2);
}
}
else{
int id;
scanf("%d",&id);
del[id] = true;
}
/***** 统计答案 ******/
int ans = ;
for(int i=;i<(<<k);i++){
if(!Max[i].empty()) temp1 = Max[i].top(); //下面从最大堆中取没被删除的最大;
while(!Max[i].empty() && del[temp1.p]){
Max[i].pop();
temp1 = Max[i].top();
}
if( Max[i].empty()){ //最大堆为空,没temp1没取到元素;直接退出。
ans = ; break;
}
if(!Min[i].empty()) temp2 = Min[i].top(); //下面从最小堆中取没被删除的最小;
while(!Min[i].empty() && del[temp2.p]){
Min[i].pop();
temp2 = Min[i].top();
}
if( Min[i].empty()){ //最小堆为空,没temp2没取到元素;
ans = ; break;
}
ans = max(ans,temp1.d-temp2.d);
}
printf("%d\n",ans);
}
}
}

hdu4666 最远曼哈顿距离的更多相关文章

  1. hdu 4666:Hyperspace(最远曼哈顿距离 + STL使用)

    Hyperspace Time Limit: 20000/10000 MS (Java/Others)    Memory Limit: 65535/65535 K (Java/Others)Tota ...

  2. poj 2926:Requirements(最远曼哈顿距离,入门题)

    Requirements Time Limit: 5000MS   Memory Limit: 65536K Total Submissions: 3908   Accepted: 1318 Desc ...

  3. POJ-2926 Requirements 最远曼哈顿距离

    题目链接:http://poj.org/problem?id=2926 题意:求5维空间的点集中的最远曼哈顿距离.. 降维处理,推荐2009武森<浅谈信息学竞赛中的“0”和“1”>以及&l ...

  4. [HDU 4666]Hyperspace[最远曼哈顿距离][STL]

    题意: 许多 k 维点, 求这些点之间的最远曼哈顿距离. 并且有 q 次操作, 插入一个点或者删除一个点. 每次操作之后均输出结果. 思路: 用"疑似绝对值"的思想, 维护每种状态 ...

  5. HDU 4666 Hyperspace (最远曼哈顿距离)

    Hyperspace Time Limit: 20000/10000 MS (Java/Others)    Memory Limit: 65535/65535 K (Java/Others)Tota ...

  6. HDU 4666 最远曼哈顿距离

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=4666 关于最远曼哈顿距离的介绍: http://blog.csdn.net/taozifish/ar ...

  7. HDU 4666 Hyperspace (2013多校7 1001题 最远曼哈顿距离)

    Hyperspace Time Limit: 20000/10000 MS (Java/Others)    Memory Limit: 65535/65535 K (Java/Others)Tota ...

  8. 2018 Multi-University Training Contest 10 CSGO(HDU - 6435)(最远曼哈顿距离)

    有 n 种主武器,m 种副武器.每种武器有一个基础分数k种属性值 X[i] . 选出一种主武器 mw 和一种副武器 sw,使得两种武器的分数和 + 每个属性的差值尽量大.(参考下面的式子) 多维的最远 ...

  9. Codeforces 491B. New York Hotel 最远曼哈顿距离

    最远曼哈顿距离有两个性质: 1: 对每一个点(x,y)  分别计算  +x+y , -x+y , x-y , -x-y 然后统计每种组合的最大值就能够了, 不会对结果产生影响 2: 去掉绝对值 , 设 ...

随机推荐

  1. 使用EMMET中的小坑

    使用EMMET写HTML的时候,是一个非常爽的事情.但是今天我使用时,发现一个小坑.以前倒也没有注意,不过需要非常的小心. form[action="/process" metho ...

  2. 怎样在thinkphp里面执行原生的sql语句

    $Model = new Model(); $sql = "select * from `order`"; $voList = $Model->query($sql); 只是 ...

  3. power desinger 学习笔记<八>

    转-PowerDesigner 把Comment复制到name中和把name复制到Comment 在使用PowerDesigner对数据库进行概念模型和物理模型设计时,一般在NAME或Comment中 ...

  4. SpringMVC4+thymeleaf3的一个简单实例(篇四:form表单数据验证)

    关于表单数据验证有很多中方法,这里我仅介绍JSR303注解验证.JSR303仅仅是一个规范,这里我们要用到它的一个实现:hibernate-validator. 注意在spring的配置文件sprin ...

  5. (java)从零开始之--异常处理(以文件拷贝为例)

    开发过程中避免不了对异常的处理,但是异常的处理又不能乱throw 下面是简单的抛异常处理 public static void CopyFile(String souFile,String dirFi ...

  6. 最新xgboost python32位下安装xgboost

    网上很多windows python下安装xgboost都是很简单的几步无非是visual studio2013以上版本编译,安装.但现在最新的xgboost已经移除了c++工程文件,找到旧版本的也多 ...

  7. HDOJ 2036

    错误代码: #include<stdio.h>#include<math.h>int main(){ int x[102],y[102]; int i,n; float s,a ...

  8. opencv Iplimage结构简介

    IplImage 结构解读: typedef struct _IplImage{int nSize;                    /* IplImage大小 */int ID;        ...

  9. grep操作

    这个程序的名称来自Unix文本编辑器ed类似操作的命令: g/re/p 这个命令搜索整个文件中匹配给定正则表达式的文本行,并显示出来.有很多不同的命令行用于改变grep的默认行为,包括显示出不匹配的文 ...

  10. phpcms 如何获取文章

    请求地址http://127.0.0.1/phpcms/index.php?m=content&c=index&a=show&catid=6&id=8 先来判断地址对应 ...