HDU 5046 Airport(dlx)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5046
题意:n个城市修建m个机场,使得每个城市到最近进场的最大值最小。
思路:二分+dlx搜索判定。
#include <iostream>
#include <map>
#include <string>
#include <stdio.h>
#include <vector>
#include <set>
#include <algorithm>
#include <string.h>
#include <fstream>
#include <tchar.h>
#include <sstream>
using namespace std;
];
int KK;
int m;
class CDancingLinks
{
protected:
struct DancingLinksNode
{
DancingLinksNode* left;
DancingLinksNode* right;
DancingLinksNode* down;
DancingLinksNode* up;
int col;
int row;
};
typedef DancingLinksNode Node;
int *m_columnEleNumbers;
int m_colNumber;
int m_rowNumber;
Node* m_pool;
Node** m_head;
int m_curUsePoolIndex;
void _Remove(Node* cur)
{
--m_columnEleNumbers[cur->col];
for(Node* p=cur->down;p!=cur;p=p->down)
{
p->left->right=p->right;
p->right->left=p->left;
}
}
void _Resume(Node* cur)
{
++m_columnEleNumbers[cur->col];
for(Node* p=cur->up;p!=cur;p=p->up)
{
p->left->right=p;
p->right->left=p;
}
}
int astar()
{
Node* p=_GetNode();
++KK;
;
for(Node* q=p->left;q!=p;q=q->left) if(KK!=visit[q->col])
{
visit[q->col]=KK;
++ans;
for(Node* r=q->up;r!=q;r=r->up) for(Node* t=r->left;t!=r;t=t->left)
{
visit[t->col]=KK;
}
}
return ans;
}
bool _SearchSolution(const int depth,std::vector<int> &solution)
{
Node* p=_GetNode();
if(p->left==p) return true;
if(depth+astar()>m) return false;
;
;
for(Node* q=p->left;q!=p;q=q->left)
{
if(m_columnEleNumbers[q->col]<Min)
{
Min=m_columnEleNumbers[q->col];
MinColumnIndex=q->col;
}
}
for(Node* q=_GetNode(MinColumnIndex)->down;q!=_GetNode(MinColumnIndex);q=q->down)
{
_Remove(q);
solution.push_back(q->row);
for(Node* rr=q->right;rr!=q;rr=rr->right) _Remove(rr);
,solution)) return true;
for(Node* rr=q->left;rr!=q;rr=rr->left) _Resume(rr);
solution.pop_back();
_Resume(q);
}
return false;
}
Node* _GetNode(int id) { return m_pool+id; }
void _ReleaseMemory()
{
if(m_columnEleNumbers)
{
delete[] m_columnEleNumbers;
m_columnEleNumbers=nullptr;
}
if(m_pool)
{
delete[] m_pool;
m_pool=nullptr;
}
if(m_head)
{
delete[] m_head;
m_head=nullptr;
}
}
public:
CDancingLinks():m_colNumber(-),m_rowNumber(-),
m_columnEleNumbers(nullptr),m_pool(nullptr),m_head(nullptr) {}
/***
列下标为[1,Column]
***/
CDancingLinks(const int Column,const int Row):
m_columnEleNumbers(nullptr),m_pool(nullptr),m_head(nullptr)
{
SetSize(Column,Row);
}
/***
列下标为[1,Column]
***/
void SetSize(const int Column,const int Row)
{
m_colNumber=Column;
m_rowNumber=Row;
_ReleaseMemory();
m_columnEleNumbers=];
m_pool=)+];
m_head=];
Clear();
}
void Clear()
{
;i<=m_colNumber;++i)
{
Node* cur=_GetNode(i);
cur->left=((i==m_colNumber)?_GetNode():_GetNode(i+));
cur->right=((==i)?_GetNode(m_colNumber):_GetNode(i-));
m_columnEleNumbers[i]=;
cur->up=cur->down=_GetNode(i);
cur->col=i;
cur->row=;
}
;i<=m_rowNumber;++i) m_head[i]=NULL;
m_curUsePoolIndex=m_colNumber+;
}
~CDancingLinks()
{
_ReleaseMemory();
}
void AddElement(const int row,const int col)
{
Node* cur=m_pool+(m_curUsePoolIndex++);
cur->up=_GetNode(col);
cur->down=_GetNode(col)->down;
m_pool[col].down->up=cur;
m_pool[col].down=cur;
if(m_head[row]==NULL)
{
m_head[row]=cur->left=cur->right=cur;
}
else
{
cur->left=m_head[row]->left;
cur->right=m_head[row];
m_head[row]->left->right=cur;
m_head[row]->left=cur;
}
++m_columnEleNumbers[col];
cur->col=col;
cur->row=row;
}
bool GetSolution(std::vector<int> &Solution)
{
,Solution);
}
};
][];
][];
int n;
];
CDancingLinks A;
inline long long dist(int i,int j)
{
]-a[j][]))+abs(a[i][]-a[j][]);
}
int ok(long long M)
{
A.Clear();
;i<=n;i++) ;j<=n;j++) if(dis[i][j]<=M)
{
A.AddElement(i,j);
}
vector<int> ans;
return A.GetSolution(ans);
}
long long cal()
{
A.SetSize(n,n);
;
int i,j;
;i<=n;i++) ;j<=n;j++) dis[i][j]=dist(i,j),d[num++]=dis[i][j];
sort(d,d+num);
int M=unique(d,d+num)-d;
,high=M-;
long long ans=d[high];
while(low<=high)
{
;
;
;
}
return ans;
}
int main()
{
int T;
scanf("%d",&T);
;i<=T;++i)
{
scanf("%d%d",&n,&m);
;j<=n;++j) scanf(],&a[j][]);
printf("Case #%d: %I64d\n",i,cal());
}
}
HDU 5046 Airport(dlx)的更多相关文章
- HDU 5046 Airport(DLX反复覆盖)
HDU 5046 Airport 题目链接 题意:给定一些机场.要求选出K个机场,使得其它机场到其它机场的最大值最小 思路:二分+DLX反复覆盖去推断就可以 代码: #include <cstd ...
- HDU 5046 Airport【DLX重复覆盖】
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=5046 题意: 给定n个城市的坐标,要在城市中建k个飞机场,使城市距离最近的飞机场的最长距离最小,求这 ...
- (中等) HDU 5046 Airport ,DLX+可重复覆盖+二分。
Description The country of jiuye composed by N cites. Each city can be viewed as a point in a two- d ...
- hdu 5046 二分+DLX模板
http://acm.hdu.edu.cn/showproblem.php?pid=5046 n城市建k机场使得,是每个城市最近机场的距离的最大值最小化 二分+DLX 模板题 #include < ...
- HDU 5046 Airport ( Dancing Links 反复覆盖 )
今年上海网络赛的一道题目 , 跟 HDU 2295 如出一辙 . 就是距离的计算一个是欧几里得距离 , 一个是曼哈顿距离 学完DLX感觉这题好水 ,就是一个裸的反复覆盖 注意下别溢出即可了 #incl ...
- hdu 5046 Airport 二分+重复覆盖
题目链接 给n个点, 定义两点之间距离为|x1-x2|+|y1-y2|. 然后要选出k个城市建机场, 每个机场可以覆盖一个半径的距离. 求在选出点数不大于k的情况下, 这个半径距离的最大值. 二分半径 ...
- HDU 3335 Divisibility (DLX)
Divisibility Time Limit:1000MS Memory Limit:32768KB 64bit IO Format:%I64d & %I64u Submit ...
- 【HDOJ】5046 Airport
DLX简单题目. /* 5046 */ #include <iostream> #include <string> #include <map> #include ...
- HDU 2295.Radar (DLX重复覆盖)
2分答案+DLX判断可行 不使用的估计函数的可重复覆盖的搜索树将十分庞大 #include <iostream> #include <cstring> #include < ...
随机推荐
- 静态关键字static
//静态关键字的使用static //类里面的普通成员是属于对象的,不是属于类的(调用的时候是用对象调用) //什么叫做静态的:类静态成员是属于类的,不是属于每个对象的 //定义静态成员用static ...
- java.lang.UnsatisfiedLinkError: no sapjco3 in java.library.path
1.system32添加sapjco3.dll 2.tomcat bin下添加sapjco3.dll 3.项目中添加sapjco3.jar 包
- 对比其它软件方法评估敏捷和Scrum
一般来说,选择一种软件开发方法,更像是加入一个邪教组织,而不像是做出了一个技术决策.许多公司甚至从未试图去评估这些方法,而仅仅是盲目采用最流行的方法,这就造成了如今五花八门的各种敏捷方法.因此本文将使 ...
- SQL Server 复制 订阅与发布
SQL Server 复制 订阅与发布 通过SQL Server 2008数据库复制实现数据库同步备份 SqlServer2008 数据库同步的两种方式(Sql JOB) SqlServer2008 ...
- 【Pro ASP.NET MVC 3 Framework】.学习笔记.8.SportsStore:管理
管理功能,如何身份认证,对controller和action方法过滤安全的访问,并在用户需要时提供证书. 1 添加分类管理 方便管理的controller,有两类页面,List页面和edit页面. 1 ...
- nginx完美支持yii2框架
nginx完美支持yii2框架 server {listen 80;server_name www.peita.net peita.net;# default_server;access_log /d ...
- NSHashtable and NSMaptable
本文转自Nidom的博客,原文:<NSHashtable & NSMaptable> NSSet, NSDictionary, NSArray是Foundation框架关于集合 ...
- HDU 5795:A Simple Nim(博弈)
http://acm.hdu.edu.cn/showproblem.php?pid=5795 A Simple Nim Problem Description Two players take t ...
- 20145227《Java程序设计》第2次实验报告
20145227<Java程序设计>第2次实验报告 实验步骤与内容 一.实验内容 1. 初步掌握单元测试和TDD 2. 理解并掌握面向对象三要素:封装.继承.多态 3. 初步掌握UML建模 ...
- SpringMVC 接收ajax发送的数组对象
本文粘贴自:http://my.oschina.net/jiefalcon/blog/384153?fromerr=24Lewn46 [转]SpringMVC @RequestBody接收Json对象 ...