POJ 2288 Islands and Bridges (状压DP,变形)
题意:
给一个无向图,n个点m条边,每个点有点权,要求找到一条哈密顿路径,使得该路径的f(path)值最大。输出f值,若有多条最大f值的路径,输出路径数量。
f值由如下3点累加而来:
(1)所有点权之和。
(2)路径上相邻两点的点权之积。
(3)路径上如果有连续的3个点是一个三角形(即3点成环),则累加三点的点权之积。
思路:
根据f值的计算方式,第一项基本是不会变的,其他两项与路径有关。由于需要计算第3点,所以状态还需要记录每个状态的最后两个点(有序的),来判断是否为三角形。那么状态表示为[哪些点浏览过][倒数第2个点][末节点],如果是在刚开始,只有1个点,那么第二维就是0就行了。路径数是根据DP的过程来计算的,开一个和状态数一样的数组保存即可。
注意点:路径统计要小心,图可能不连通,可能只有1个点,路径数可能爆LL?
//#include <bits/stdc++.h>
#include <iostream>
#include <cstdio>
#include <cstring>
#include <cmath>
#include <deque>
#include <map>
#include <algorithm>
#include <vector>
#include <iostream>
#define pii pair<int,int>
#define INF 0x3f3f3f3f
#define LL long long
#define ULL unsigned long long
using namespace std;
const double PI = acos(-1.0);
const int N=;
int n, w[N];
LL cnt[<<][N][N], dp[<<][N][N],ans, ans2;
bool g[N][N]; void fuck(int s,int i,int k)
{
for(int j=; j<=n; j++) //枚举终点
{
if( (s&(<<j-)) || !g[i][j] ) continue;//已经走过or无路径 LL c=cnt[s][k][i];
LL v=dp[s][k][i]+w[i]*w[j];
if( g[k][j] ) v+=w[k]*w[i]*w[j]; //三角形出现 LL &cc=cnt[s|(<<j-)][i][j];
LL &dd=dp[s|(<<j-)][i][j];
if( dd<=v )
{
if(dd==v) cc+=c;
else cc=c;
dd=v;
}
}
}
void cal()
{
memset(dp,-,sizeof(dp));
memset(cnt,,sizeof(cnt));
ans=-;
ans2=-;
for(int i=; i<=n; i++)
{
dp[<<i-][][i]=;
cnt[<<i-][][i]=;
}
for(int s=; s<(<<n); s++)
{
for(int i=; i<=n; i++) //枚举k->i结尾
{
if( ( s&(<<i-) )== ) continue;
for(int k=; k<=n; k++)
{
if( k>&&(s&(<<k-))== || k==i ) continue;
if( dp[s][k][i]< ) continue;
fuck(s,i,k);
}
}
}
for(int i=; i<=n; i++) //枚举k->i结尾
{
for(int k=; k<=n; k++)
{
if(i==k || dp[(<<n)-][k][i]< ) continue;
if( ans==dp[(<<n)-][k][i] )
ans2+=cnt[(<<n)-][k][i];
else if( ans<dp[(<<n)-][k][i] )
{
ans=dp[(<<n)-][k][i];
ans2=cnt[(<<n)-][k][i];
}
}
}
} int main()
{
//freopen("input.txt","r",stdin);
int m, a, b, t, sum;cin>>t;
while(t--)
{
sum=;
scanf("%d%d",&n,&m);
memset(g,,sizeof(g));
for(int i=; i<=n; i++)
{
scanf("%d",&w[i]);
sum+=w[i];
}
for(int i=; i<m; i++)
{
scanf("%d%d",&a,&b);
g[a][b]=g[b][a]=true;
}
if(n==) printf("%d 1\n", w[]);
else
{
cal();
if(ans<) printf("0 0\n");
else printf("%lld %lld\n", ans+sum, ans2/);
}
}
return ;
}
AC代码
POJ 2288 Islands and Bridges (状压DP,变形)的更多相关文章
- poj 2288 Islands and Bridges ——状压DP
题目:http://poj.org/problem?id=2288 状压挺明显的: 一开始写了(记忆化)搜索,但一直T: #include<iostream> #include<cs ...
- poj 2288 Islands and Bridges——状压dp(哈密尔顿回路)
题目:http://poj.org/problem?id=2288 不知为什么记忆化搜索就是WA得不得了! #include<iostream> #include<cstdio> ...
- [poj2288] Islands and Bridges (状压dp)
Description Given a map of islands and bridges that connect these islands, a Hamilton path, as we al ...
- POJ 1185 炮兵阵地(状压DP)
炮兵阵地 Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 26426 Accepted: 10185 Descriptio ...
- POJ 2411 Mondriaan's Dream -- 状压DP
题目:Mondriaan's Dream 链接:http://poj.org/problem?id=2411 题意:用 1*2 的瓷砖去填 n*m 的地板,问有多少种填法. 思路: 很久很久以前便做过 ...
- POJ 2411 Mondriaan's Dream ——状压DP 插头DP
[题目分析] 用1*2的牌铺满n*m的格子. 刚开始用到动规想写一个n*m*2^m,写了半天才知道会有重复的情况. So Sad. 然后想到数据范围这么小,爆搜好了.于是把每一种状态对应的转移都搜了出 ...
- 【POJ 2923】Relocation(状压DP+DP)
题意是给你n个物品,每次两辆车运,容量分别是c1,c2,求最少运送次数.好像不是很好想,我看了网上的题解才做出来.先用状压DP计算i状态下,第一辆可以运送的重量,用该状态的重量总和-第一辆可以运送的, ...
- POJ 1185 炮兵阵地 (状压DP)
题目链接 题意 : 中文题不详述. 思路 :状压DP,1表示该位置放炮弹,0表示不放.dp[i][j][k],代表第 i 行的状态为k时第i-1行的状态为 j 时放置的最大炮弹数.只是注意判断的时候不 ...
- 动态规划晋级——POJ 3254 Corn Fields【状压DP】
转载请注明出处:http://blog.csdn.net/a1dark 分析:刚开始学状压DP比较困难.多看看就发现其实也没有想象中那么难.这道题由于列数较小.所以将行压缩成二进制来看.首先处理第一行 ...
- POJ 1185 炮兵阵地 【状压DP】
<题目链接> 题目大意: 司令部的将军们打算在N*M的网格地图上部署他们的炮兵部队.一个N*M的地图由N行M列组成,地图的每一格可能是山地(用"H" 表示),也可能是平 ...
随机推荐
- linux消息队列相关操作
/* 发送消息队列 */ #include <stdio.h>#include <stdlib.h>#include <string.h>#include < ...
- Spring入门第十七课
AOP编程 问题: 代码混乱: 越来越多的非业务需求(日志和验证等)加入后,原有的业务方法急剧膨胀,每个方法在处理核心逻辑的同事还必须兼顾其他多个关注点. 代码分散:以日志需求为例,只是为了满足这个单 ...
- location对象介绍
Location 对象 Location 对象 Location 对象包含有关当前 URL 的信息. Location 对象是 Window 对象的一个部分,可通过 window.location 属 ...
- POJ 2348 Euclid's Game (博弈)
题意:给定两个整数,两个人轮流操作,每次可以用较大数减去较小数的整数倍,当一个数变成0时,则结束,问谁会胜. 析:很明显如果 a == b 那么就可以直接结束了,那么如果 a > b我们可以交换 ...
- HDU - 5887 2016青岛网络赛 Herbs Gathering(形似01背包的搜索)
Herbs Gathering 10.76% 1000ms 32768K Collecting one's own plants for use as herbal medicines is pe ...
- Deep Learning - Install the Development Environment
WLS(Windows Subsystem for Linux) Base WLS Installation Guide Initializing a newly installed distro W ...
- es6常用方法
一.let 和 constlet 声明变量,只在所在的块区有效,不存在变量提升:var 存在变 量提升const 声明常量,只在所在块区有效 二.变量的解构赋值1.数组的解构赋值let [a, b, ...
- react学习之redux和redux-react用法
前言 redux和react-redux的关系: redux就是一个存储数据的对象,并提供了获取/设置store中的属性的解决方案,react-redux是连接react和redux桥梁的封装. ...
- javascript中的style只能取到在HTML中定义的css属性
如果在css中定义的 li{ width:100px; left:100px; top:; position:absolute; font-style:normal; } 这样执行: oli[0].s ...
- discuz 3.x ssrf分析
discuz 3.x版本ssrf漏洞分析 漏洞促发点\souce\module\forum\forum_ajax.php 最后看到了这里 ***$_GET['action']='downremotei ...