hdu3311
#include <bits/stdc++.h>
using namespace std;
#define maxn 10000
#define INF 6e8
bool inq[];
int dp[][],v[];
struct re{
int a,b,c;
}a[maxn];
int l,n,m,p,head[],dis[][];
void arr(int x,int y,int z)
{
a[++l].a=head[x];
a[l].b=y;
a[l].c=z;
head[x]=l;
}
void spfa()
{
queue<int> q;
for (int s=;s<=n+m;s++)
{
for (int j=;j<=n+m;j++)
dis[s][j]=INF;
dis[s][s]=;
q.push(s); inq[s]=;
while (!q.empty())
{
int x=q.front(); q.pop();
int u=head[x];
while (u)
{
int v=a[u].b;
if (dis[s][v]>dis[s][x]+a[u].c)
{
dis[s][v]=dis[s][x]+a[u].c;
if (!inq[v])
{
q.push(v); inq[v]=;
}
}
u=a[u].a;
}
inq[x]=;
}
}
}
void get_ans()
{
for (int i=;i<=(<<n)-;i++)
for (int j=;j<=n+m;j++)
dp[i][j]=INF;
for (int i=;i<=n;i++)
dp[<<(i-)][i]=;
for (int i=;i<=(<<n)-;i++)
{
for (int j=;j<=n+m;j++)
{
for (int k=i;k;k=(k-)&i)
if (dp[i][j]>dp[k][j]+dp[i^k][j])
dp[i][j]=dp[k][j]+dp[i^k][j];
} for (int k1=;k1<=n+m;k1++)
for (int k2=;k2<=n+m;k2++)
if (dp[i][k1]>dp[i][k2]+dis[k2][k1])
dp[i][k1]=dp[i][k2]+dis[k2][k1];
} }
int main()
{
freopen("noip.in","r",stdin);
std::ios::sync_with_stdio(false);
while (cin>>n>>m>>p&&n>)
{
l=;memset(head,,sizeof(head));
for (int i=;i<=m+n;i++)
{
cin>>v[i];
arr(i,,v[i]);
}
int c,d,e;
for (int i=;i<=p;i++)
{
cin>>c>>d>>e;
arr(c,d,e); arr(d,c,e);
}
spfa();
get_ans();
cout<<dp[(<<n)-][]<<endl;
}
return ;
}
hdu3311的更多相关文章
- 【hdu3311】Dig The Wells(斯坦纳树+dp)
传送门 题意: 给出\(n\)个重要点,还有其余\(m\)个点,\(p\)条边. 现在要在这\(n+m\)个点中挖几口水井,每个地方的费用为\(w_i\).连接边也有费用. 问使得这\(n\)个地点都 ...
随机推荐
- Docker部署Consul集群
服务介绍 Consul是一种分布式.高可用.支持水平扩展的服务注册与发现工具.包含的特性有:服务发现.健康检查.键值存储.多数据中心和服务管理页面等. 官方架构设计图: 图中包含两个Consul数据中 ...
- PHP7 学习笔记(八)JetBrains PhpStorm 2017.1 x64 MySQL数据库管理工具的使用
填写基本信息 这时候我们可以看到已经连接成功的数据库了 打开一个表,我们可以很清楚的看到数据库表的数据 切换到DDL模式
- SQL Server进阶(二)字段类型
概述 系统数据类型详情 SqlDbType namespace System.Data { // // 摘要: // 指定要用于 System.Data.SqlClient.SqlParameter ...
- Spring MVC 源码分析
Spring MVC SpringMVC中扮演关键角色的DispatcherServlet类. 1 DispatcherServlet 1.1DispatcherServlet 类图 1.2 初始 ...
- class特性
每个HTML元素都可以附带一个class特性.有时候,你希望有一种方法可以指定多个元素并将这些元素和页面上的其他元素区分出来,而不是单独指定文档中的某个元素. <!DOCTYPE html> ...
- 12章 搜索框架ElasticSearch介绍和整合SpringBoot 4节课
1.搜索引擎知识和搜索框架elasticsearch基本介绍 简介:通过京东电商 介绍什么是搜索引擎,和开源搜索框架ElasticSearch6.x新特性介绍 前言:介绍ES的主要特点和使用场 ...
- shiroWeb项目-认证及MD5认证信息在页面显示(十)
realm设置完整认证信息 // realm的认证方法,从数据库查询用户信息 @Override protected AuthenticationInfo doGetAuthenticationInf ...
- 改环境变量改出问题了,vi,ls这些命令都不能用了,怎么办
1.出现这个问题肯定是以前的基本环境变量都用不了了(大部分情况就是多了一个空格) 解决办法: cd /usr/bin 下执行vi命令 修改环境变量 然后source /etc/profile ...
- Gaussian discriminant analysis 高斯判别分析
高斯判别分析(附Matlab实现) 生成学习算法 高斯判别分析(Gaussian Discriminant analysis,GDA),与之前的线性回归和Logistic回归从方法上讲有很大的不同,G ...
- 【windows核心编程】注入DLL时BUG排除与调试
DLL注入排除bug的思路步骤. 1.在VS中监视输入err,hr检查DLL是否注入成功 2.OD断点loadlibraryW,loadlibraryA是否已经注入成功,eax是否有值. 3.检查路径 ...