没看过TSP,先mark

 //4838039 2011-10-27 23:04:15 Accepted 4026 2343MS 31044K 3143 B C++ Geners
//状态压缩DP的TSP问题
//优先级位运算小于判等 , 还有各种细节各种出错
#include <cstdio>
#include <cstring>
#include <stdlib.h>
#define mabs(a) (a>0?a:-(a)) using namespace std; typedef long long ll;
const int maxn=<<;
int gcd(int a, int b)
{
return b?gcd(b, a%b):a;
} int g[][];
int map[][], cnt;
int n, m;
ll dp[maxn][];
struct Node {
int x,y;
}node[]; void init ()
{
for (int i= ; i< ; ++i)
for (int j= ; j< ; ++j)
g[i][j]=gcd(i, j);
} bool valid(int sta, int k, int pre)
{
int x=node[k].x,xx=node[pre].x;
int y=node[k].y,yy=node[pre].y; if(map[x][y]> || map[xx][yy]>)
return false;//如果2个点不都是0。
int d=g[mabs(x-xx)][mabs(y-yy)];
for (int i= ; i<=d ; ++i)
{
int tmpx=xx+i*(x-xx)/d;
int tmpy=yy+i*(y-yy)/d;
if(map[tmpx][tmpy] == )
return false;//中间点forbidden
if(map[tmpx][tmpy] <= )
{
if((sta&(<<(-map[tmpx][tmpy]))) == )
{
return false;
}//中间有未遍历的0。
}
}
return true;
} void DP()
{
memset (dp, , sizeof(dp));
int limit=<<cnt;
for (int i= ; i<limit ; ++i)
{
for (int j= ; j<cnt ; ++j)
{
dp[<<j][j]=1ll;//初始以每个点开始的情况
if(i&(<<j))
for (int k= ; k<cnt ; ++k)
{
if(k==j)continue;
if(i^(<<j)& (<<k) ) //k是从此时出发的点,j是要去的点
if(valid(i,j,k))
{
dp[i][j]+=dp[i^(<<j)][k];
}
}
}
}
ll ans=0ll;
for (int i= ; i<cnt ; ++i)
ans+=dp[limit-][i];
printf("%I64d\n", ans); } int main ()
{
init ();
while (~scanf("%d%d", &n, &m))
{
cnt=;
for (int i= ; i<n ; ++i)
{
for (int j= ; j<m ; ++j)
{
scanf("%d",&map[i][j]);
if(map[i][j] == )
{
node[cnt].x=i;
node[cnt].y=j;
map[i][j]=-cnt;//映射到小于等于0
cnt++;
}
//printf(" %d \n",map[i][j]);
}
}
DP();
}
return ;
}

hdu 4026 2011上海赛区网络赛F TSP ****的更多相关文章

  1. hdu 4025 2011上海赛区网络赛E 压缩 ***

    直接T了,居然可以这么剪枝 题解链接:点我 #include<cstdio> #include<map> #include<cstring> #define ll ...

  2. hdu 4045 2011北京赛区网络赛F 组合数+斯特林数 ***

    插板法基础知识 斯特林数见百科 #include<iostream> #include<cmath> #include<cstdio> #include<cs ...

  3. hdu 4036 2011成都赛区网络赛F 模拟 **

    为了确保能到达终点,我们需要满足下面两个条件 1.能够到达所有山顶 2.能够在遇到苦土豆时速度大于他 二者的速度可以用能量守恒定律做,苦土豆的坐标可通过三角形相似性来做 #include<cst ...

  4. hdu 4023 2011上海赛区网络赛C 贪心+模拟

    以为是贪心,结果不是,2333 贪心最后对自己绝对有利的情况 点我 #include<cstdio> #include<iostream> #include<algori ...

  5. hdu 4028 2011上海赛区网络赛H dp+map离散

    一开始用搜索直接超时,看题解会的 #include<iostream> #include<cstdio> #include<map> #include<cst ...

  6. hdu 4027 2011上海赛区网络赛G 线段树 成段平方根 ***

    不能直接使用成段增减的那种,因为一段和的平方根不等于平方根的和,直接记录是否为1,是1就不需要更新了 #include<cstdio> #include<iostream> # ...

  7. hdu 4006 优先队列 2011大连赛区网络赛F **

    签到题都要想一会 #include<cstdio> #include<iostream> #include<algorithm> #include<cstri ...

  8. hdu 4035 2011成都赛区网络赛E 概率dp ****

    太吊了,反正我不会 /* HDU 4035 dp求期望的题. 题意: 有n个房间,由n-1条隧道连通起来,实际上就形成了一棵树, 从结点1出发,开始走,在每个结点i都有3种可能: 1.被杀死,回到结点 ...

  9. hdu 4044 2011北京赛区网络赛E 树形dp ****

    专题训练 #include<stdio.h> #include<iostream> #include<string.h> #include<algorithm ...

随机推荐

  1. ASP.NET MVC Dropdownlist

    本文介绍如何在网页里显示DropDownList. Step 1: 在Control里面添加方法 public ActionResult ShowDropDownList() { return Vie ...

  2. FFmpeg-20160422-snapshot-bin

    ESC 退出 0 进度条开关 1 屏幕原始大小 2 屏幕1/2大小 3 屏幕1/3大小 4 屏幕1/4大小 S 下一帧 [ -2秒 ] +2秒 ; -1秒 ' +1秒 下一个帧 -> -5秒 F ...

  3. Python: 程序print到文件中

    Python 3.x 将输出内容写入到一个文件,需要两个命令.open指明Python用什么文件名,w 意味着我们要写入该文件, encoding=”utf-8″指明Python如何把中文写入该文件. ...

  4. Effective C++ -----条款11: 在operator=中处理“自我赋值”

    确保当对象自我赋值时operator=有良好行为.其中技术包括比较“来源 对象”和“目标对象”的地址.精心周到的语句顺序.以及copy-and-swap. 确定任何函数如果操作一个以上的对象,而其中多 ...

  5. filter 简介

    概述 filter() 方法使用指定的函数测试所有元素,并创建一个包含所有通过测试的元素的新数组. 语法 var new_arrary = arr.filter(callback[, thisArg] ...

  6. 项目之solr全文搜索工具之创建项目索引库

    以创建项目baotao core为例 1.  在example目录下创建baotao-solr文件夹: 2.  将./solr下的solr.xml拷贝到baotao-solr目录下: 3.  在bao ...

  7. C 替换字符方法

    // 444.cpp : Defines the entry point for the console application. // #include "stdafx.h" # ...

  8. Struts2拦截器之ExceptionMappingInterceptor(异常映射拦截器)

    一.异常拦截器是什么? 异常拦截器的作用是提供一个机会,可以设置在action执行过程中发生异常的时候映射到一个结果字符串而不是直接中断. 将异常整合到业务逻辑中,比如在分层系统的调用中可以从底层抛出 ...

  9. NYOJ之素数求和问题

    aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAAAsoAAAKCCAIAAABH/2gWAAAgAElEQVR4nO3dPVLjStsG4G8T5CyEdF

  10. hadoop 2.5 hdfs namenode –format 出错Usage: java NameNode [-backup] |

    在 cd  /home/hadoop/hadoop-2.5.2/bin 下 执行的./hdfs namenode -format 报错[hadoop@node1 bin]$ ./hdfs nameno ...