HDU 3001 状压DP
有道状压题用了搜索被队友骂还能不能好好训练了,,
hdu 3001 经典的状压dp
大概题意。。有n个城市 m个道路 成了一个有向图。n<=10; 然后这个人想去旅行。有个超人开始可以把他扔到任意的一个城市。。然后他就在城市之间游荡。要满足他要游玩所有的城市。。并且。每个城市最多去两次。要求路程最短。。如果他不能游完所有的城市,,那么。。就输出-1 否则 输出最短距离
如果用搜索。。。不靠谱 然后用搜索,,
怎么压缩?? 用一个整型数 i 表示他现在的状态。。显然一个城市是要用两位。。00 表示没去过 01 表示去了一次 10 表示去了两次 然后最多10个城市,。。那么一共用20位 2^20一共是。。1024*1024 也就是10^6大概吧。。 然后dp[i][j] 表示的是 当前这个状态。。并且 最后他在j城市的最短路径。。然后他可以去另外的城市 咋一看 这个时间复杂度是 。。10^6 * 10 * 10 然后加上各种判断。。还要开一个10^6 *10 的数组 然后就MLE 了,,我们发现 i 在自然数里面并不是连续的 而是离散的 我们 先找出满足条件的 i 存在一个数组inn里面 然后用二分查找 。。。相当于用了一个哈希表,,存了这么多的情况,,,然后就是dp转移了,,,,
MLE 1 wa1 : 没考虑输出-1 的情况
代码不长
#include <cstdio>
#include <cmath>
#include <algorithm>
#include <iostream>
#include <cstdlib>
#include <string>
#include <queue>
#include <cstring>
#define CL(a,b) memset(a,b,sizeof(a))
#define ll __int64
#define TEST cout<<"TEST ***"<<endl;
#define INF 0x7ffffff0
#define MOD 100000000
using namespace std; int inn[];
int dp[][];
int gra[][];
int n,m,cii; int bin(int s,int e,int v)
{
int mid=(s+e)/;
if(inn[mid]==v)return mid;
if(inn[mid]>v)return bin(s,mid,v);
else return bin(mid+,e,v);
} int initinn()
{
int i,ctt=,taginn,teminn;
for(i=;i<=;i++)
{
teminn=i;taginn=;
while(teminn)
{
if((teminn&)==)
{
taginn=;
break;
}
teminn=teminn>>;
}
if(taginn==)
{
inn[ctt++]=i;
}
}
return ctt;
} int main()
{
cii=initinn();
while(scanf("%d %d",&n,&m)!=EOF)
{
CL(gra,-);
int i,j,k,a,b,w;
int rem=INF;
int ma=(<<(*n))-;
for(i=;i<m;i++)
{
scanf("%d %d %d",&a,&b,&w);
if(gra[a][b]==-||gra[a][b]>w)
{
gra[a][b]=gra[b][a]=w;
}
} CL(dp,-);
for(i=;i<=n;i++)dp[][i]=;
for(i=;i<=n;i++)gra[][i]=gra[i][]=gra[i][i]=;
for(i=;inn[i]<=ma;i++)
{
a=inn[i];
for(j=;j<=n;j++)
{
if(dp[i][j]==-)continue;
for(k=;k<=n;k++)
{
if(gra[j][k]==-)continue;
b=k-;
if(a&(<<(*b+)))continue;
w=a+(<<(*b));
w=bin(,cii,w);
if(dp[w][k]==-||dp[w][k]>dp[i][j]+gra[j][k])
dp[w][k]=dp[i][j]+gra[j][k];
}
b=; w=a;
for(k=;k<=n;k++)
{
if((w&)==)
{
b=;
break;
}
w=w>>;
}
if(b==&&dp[i][j]<rem)rem=dp[i][j];
}
}
if(rem==INF)rem=-;
printf("%d\n",rem);
}
return ;
}
HDU 3001 状压DP的更多相关文章
- hdu 3001(状压dp, 3进制)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3001 由于本题中一个点最多能够访问2次,由此可以联想到3进制; visited[i][j]表示在状态i ...
- hdu 3001(状压dp)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3001 思路:这道题类似于TSP问题,只不过题目中说明每个城市至少要走一次,至多走2次,因此要用到三进制 ...
- HDU 4778 状压DP
一看就是状压,由于是类似博弈的游戏.游戏里的两人都是绝对聪明,那么先手的选择是能够确定最终局面的. 实际上是枚举最终局面情况,0代表是被Bob拿走的,1为Alice拿走的,当时Alice拿走且满足变换 ...
- hdu 2809(状压dp)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2809 思路:简单的状压dp,看代码会更明白. #include<iostream> #in ...
- hdu 2167(状压dp)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2167 思路:经典的状压dp题,前后,上下,对角8个位置不能取,状态压缩枚举即可所有情况,递推关系是为d ...
- Engineer Assignment HDU - 6006 状压dp
http://acm.split.hdu.edu.cn/showproblem.php?pid=6006 比赛的时候写了一个暴力,存暴力,过了,还46ms 那个暴力的思路是,预处理can[i][j]表 ...
- hdu 3254 (状压DP) Corn Fields
poj 3254 n乘m的矩阵,1表示这块区域可以放牛,0,表示不能,而且不能在相邻的(包括上下相邻)两个区域放牛,问有多少种放牛的方法,全部不放也是一种方法. 对于每块可以放牛的区域,有放或者不放两 ...
- HDU 5823 (状压dp)
Problem color II 题目大意 定义一个无向图的价值为给每个节点染色使得每条边连接的两个节点颜色不同的最少颜色数. 对于给定的一张由n个点组成的无向图,求该图的2^n-1张非空子图的价值. ...
- hdu 4739 状压DP
这里有状态压缩DP的好博文 题目:题目比较神,自己看题目吧 分析: 大概有两种思路: 1.dfs,判断正方形的话可以通过枚举对角线,大概每次减少4个三角形,加上一些小剪枝的话可以过. 2.状压DP,先 ...
随机推荐
- 作业:汽车查询--弹窗显示详情,批量删除 ajax做法(0521)
作业:显示以下界面: 作业要求: 1.查看详细信息,以弹窗的形式显示,使用ajax2.批量删除 一.主页面 <!DOCTYPE html PUBLIC "-//W3C//DTD XHT ...
- HTML&CSS基础学习笔记1.21-语义化标签
语义化标签 “语义化”指的是机器在需要更少的人类干预的情况下能够研究和收集信息,让网页能够被机器理解,最终让人类受益. HTML 标签语义化是让大家直观的认识标签和属性的用途和作用,很明显<hx ...
- C++得到最大的int值
要得到最大的int值: 1.利用(unsigned int)-1,这样得到的就是unsigned int表示的最大值. 2.int值只是比unsigned int多一位符号位,所以对(unsigned ...
- Scala学习笔记--Akka
待完成 http://www.gtan.com/akka_doc/ http://my.oschina.net/mingdong/blog/297972 http://www.jdon.com/con ...
- 直播 linux上的第一个c++程序
这里用crt来直播吧: 登录到服务器上之后: 1.mkdir -p 建一个文件夹 2.ll 查看一下这个文件夹 3.cd 进入这个文件夹 4.vim 进行文本编辑 写完之后,按下esc中止输入模式,用 ...
- 程序被送入后台后,向 iOS 借时间,完成长期任务-备
12.2.2. 方案 使用UIApplication的beginBackgroundTaskWithExpirationHandler: 实例方法.在你完成任务后,调用UIApplication的en ...
- matlab 对图像操作的函数概览
转自博客:http://blog.163.com/fei_lai_feng/blog/static/9289962200991713415422/ 一. 读写图像文件 1. imread imread ...
- hadoop集群的故障概率估算
hadoop集群的机器数业界(国内)最大的在5000左右,是什么限制了集群的规模呢?有好几个原因. 1. namenode的内存大小限制 2. 机器故障概率随着机器数目增大而增大,通常一份数据存储在h ...
- ZOJ2317-Nice Patterns Strike Back:矩阵快速幂,高精度
Nice Patterns Strike Back Time Limit: 20000/10000MS (Java/Others)Memory Limit: 128000/64000KB (Java/ ...
- PHP页面静态化(转)
在很多地方都看到有PHP整站静态化的东东,怪唬人的..其实,你会静态化一个页面,那么别说整站了,想静态化多少都可以.所以关键是,首先要知道怎么静态化一个页面,了解静态化的原理是关键.. 这里就说下我个 ...