UESTC_酱神的旅行 2015 UESTC Training for Dynamic Programming<Problem M>
M - 酱神的旅行
Time Limit: 3000/1000MS (Java/Others) Memory Limit: 65535/65535KB (Java/Others)
酱神要去一棵树上旅行。
酱神制定了一个旅行计划,他要按顺序去m个树上的结点,a1,a2,a3,...,am。
酱神有一辆车,树上的每一条边既可以开车通过,也可以走过去,两种方法需要不同的时间。如果选择走路,酱神需要先把车停在结点上,在他下一次要开车的时候,必须先回到停车的结点取车。
酱神和他的爱车一开始都在a1结点上,酱神要依次访问完这m个结点最少需要多少时间。
Input
第一行两个数n,m。
1=<n,m<=5000
接下来n−1行,每行4个数,u,v,walk,drive。表示结点u和结点v之间有一条走路耗时为walk,开车耗时为drive的边。
1=<u,v<=n
1=<walk,drive<=109
最后输入m个数,a1,a2,a3,...,am, 酱神要按顺序访问的结点。
1=<ai<=n
Output
输出一个数,酱神的最小耗时。
Sample input and output
| Sample Input | Sample Output |
|---|---|
2 2 |
3 |
4 4 |
23 |
解题报告:
注意到树上两个点之间的路径是唯一的,且访问点的顺序是固定的,也就是说,经过的点的顺序是固定的,于是我们不妨令
dp(i , j )表示在路径在的第 i 个点,且是否有车的最小花费( 0 -> 无车 , 1 -> 有车 )
dp(cur , 0 ) = min ( dp( cur^1 , 0 ) , dp( cur^1 , 1 ) ) + walk_cost( i -> i + 1) )
è 直接走路过来 / 把车停在上一个点
dp(cur , 1 ) = min ( dp( cur^1 , 1 ) + car_cost(i -> i + 1) , f[r] + sum[i] ) -> r = a[i]
-> 直接开车过来 / 原来车就停在这,现在回来取(维护走路长度的前缀和)
-> f[r] = min( f[r] , dp(cur , 1) - sum[ cur ^ 1 ] );
注意到本题时限的原因,每次调用无根树转有根树时,需用BFS实现
若需要进一步降低时限,可使用LCA的离线算法,可将复杂度降低至O(N + Q),求路径上的点就不再累述.
#include <iostream>
#include <algorithm>
#include <cstring>
#include <cstdio>
#include <vector>
#define pb push_back
typedef long long ll;
const int maxn = 5e3 + ;
const ll inf = ;
using namespace std;
int n,m,prenode[maxn],cur = ,h[maxn],passnode[maxn],size,pretarget,target;
ll dp[][],f[maxn],sum[],walkdis[maxn],cardis[maxn]; typedef struct Edge
{
int target,walk,drive;
Edge(const int & target, const int & walk , const int & drive)
{
this->target = target , this->walk = walk , this->drive = drive;
}
}; vector<Edge>E[maxn]; typedef struct status
{
int pos,fat;
}; //无根树转有根树,BFS实现(比递归快 20 % )
inline void init_prenode(int pos)
{
status q[maxn*];
register int front = , rear = ;
q[rear].pos = pos , q[rear++].fat = ;
while(front < rear)
{
int thispos = q[front].pos;
int thisfat = q[front].fat;
prenode[thispos] = thisfat;
for(int i = ; i < E[thispos].size() ; ++ i)
{
int nextnode = E[thispos][i].target;
if (nextnode != thisfat)
{
if (prenode[nextnode] == thispos) continue; //剪枝
q[rear].pos = nextnode , q[rear++].fat = thispos;
}
else
walkdis[thisfat] = E[thispos][i].walk , cardis[thisfat] = E[thispos][i].drive;
}
++front;
}
} inline void add_nodes()
{
int k = prenode[pretarget];
while(k)
{
passnode[size++] = k;
k = prenode[k];
}
} int main(int argc,char *argv[])
{
int st;
scanf("%d%d",&n,&m);
for(int i = ; i < n - ; ++ i)
{
int a,b,c,d;
scanf("%d%d%d%d",&a,&b,&c,&d);
E[a].pb(Edge(b,c,d));
E[b].pb(Edge(a,c,d));
}
for(int i = ; i <= ; ++ i)
f[i] = inf;
memset(dp,,sizeof(dp));
memset(sum,,sizeof(sum));
memset(prenode,,sizeof(prenode));
memset(cardis,,sizeof(cardis));
memset(walkdis,,sizeof(walkdis));
size = ;
dp[cur][] = inf;
dp[cur][] = ;
if (m == )
{
printf("0\n");
return ;
}
scanf("%d",&pretarget);
init_prenode(pretarget);
for(int times = ; times < m ; ++ times)
{
scanf("%d",&target);
size = ;
init_prenode(target);
add_nodes();
for(int i = ; i < size ; ++ i)
{
cur ^= ;
int r = passnode[i];
sum[cur] = sum[cur^] + walkdis[r];
dp[cur][] = min(dp[cur^][] , dp[cur^][]) + walkdis[r];
dp[cur][] = min( dp[cur^][] + cardis[r] , f[r] + sum[cur]);
f[r] = min(f[r] , dp[cur][] - sum[cur]);
}
pretarget = target;
}
printf("%lld\n",min(dp[cur][],dp[cur][]));
return ;
}
UESTC_酱神的旅行 2015 UESTC Training for Dynamic Programming<Problem M>的更多相关文章
- UESTC_酱神赏花 2015 UESTC Training for Dynamic Programming<Problem C>
C - 酱神赏花 Time Limit: 3000/1000MS (Java/Others) Memory Limit: 262143/262143KB (Java/Others) Submi ...
- UESTC_男神的约会 2015 UESTC Training for Dynamic Programming<Problem J>
J - 男神的约会 Time Limit: 3000/1000MS (Java/Others) Memory Limit: 65535/65535KB (Java/Others) Submit ...
- UESTC_男神的礼物 2015 UESTC Training for Dynamic Programming<Problem A>
A - 男神的礼物 Time Limit: 3000/3000MS (Java/Others) Memory Limit: 65535/65535KB (Java/Others) Submit ...
- UESTC_邱老师选妹子 2015 UESTC Training for Dynamic Programming<Problem H>
H - 邱老师选妹子 Time Limit: 3000/1000MS (Java/Others) Memory Limit: 65535/65535KB (Java/Others) Submi ...
- UESTC_邱老师看电影 2015 UESTC Training for Dynamic Programming<Problem F>
F - 邱老师看电影 Time Limit: 3000/1000MS (Java/Others) Memory Limit: 65535/65535KB (Java/Others) Submi ...
- UESTC_邱老师玩游戏 2015 UESTC Training for Dynamic Programming<Problem G>
G - 邱老师玩游戏 Time Limit: 3000/1000MS (Java/Others) Memory Limit: 65535/65535KB (Java/Others) Submi ...
- UESTC_酱神寻宝 2015 UESTC Training for Dynamic Programming<Problem O>
O - 酱神寻宝 Time Limit: 3000/1000MS (Java/Others) Memory Limit: 65535/65535KB (Java/Others) Submit ...
- UESTC_邱老师选妹子(二) 2015 UESTC Training for Dynamic Programming<Problem I>
I - 邱老师选妹子(二) Time Limit: 3000/1000MS (Java/Others) Memory Limit: 65535/65535KB (Java/Others) Su ...
- UESTC_导弹拦截 2015 UESTC Training for Dynamic Programming<Problem N>
N - 导弹拦截 Time Limit: 3000/1000MS (Java/Others) Memory Limit: 65535/65535KB (Java/Others) Submit ...
随机推荐
- Eclipse自动补全功能轻松设置 || 不需要修改编辑任何文件
本文介绍如何设置Eclipse代码自动补全功能.轻松实现输入任意字母均可出现代码补全提示框. Eclipse代码自动补全功能默认只包括 点"." ,即只有输入”." ...
- JSP SMARTUPLOAD组件:上传文件时同时获取表单参数
原因很简单: 注意更改from 属性啊!否则为null! 因为你用jspsmartuploadsmart时post请求 的格式是multipart/form-data,即enctype="m ...
- UVA10304---(区间DP)
第一开始想着枚举根节点,然后记忆化搜索..结果TLE,最后还是看了一眼题解瞬间明白了..唉,还是思维太局限了 由于数据是按照从小到大排列的,可以自然地组成一颗二叉排序树. 设dp[i][j]是区间[i ...
- 【转】多核CPU运行模式
多核CPU运行模式主要有以下三种: •非对称多处理(Asymmetric multiprocessing,AMP)——每个CPU内核运行一个独立的操作系统或同一操作系统的独立实例(instantiat ...
- poj 2385 Apple Catching(dp)
Description It and ) in his field, each full of apples. Bessie cannot reach the apples when they are ...
- Java与面向对象
一.面向过程的思想和面向对象的思想 面向对象和面向过程的思想有着本质上的区别, 作为面向对象的思维来说,当你拿到一个问题时,你分析这个问题不再是第一步先做什么,第二步再做什么,这是面向过程的思维,你应 ...
- android recover 系统代码分析 -- 选择进入
最近做Recovery的规范及操作指导文档,花了一些时间将流程搞清. Android利用Recovery模式,进行恢复出厂设置,OTA升级,patch升级及firmware升级.而在进入Recover ...
- VBA清除Excelpassword保护,2003/2007/2010均适用
Sub Macro1() ' ' Breaks worksheet and workbook structure passwords. Jason S ' probably originator of ...
- POJ 3114 Countries in War(强连通+最短路)
POJ 3114 Countries in War 题目链接 题意:给定一个有向图.强连通分支内传送不须要花费,其它有一定花费.每次询问两点的最小花费 思路:强连通缩点后求最短路就可以 代码: #in ...
- 百度地图 Android SDK - 检索功能使用的简单演示样例
百度地图 SDK 不仅为广大开发人员提供了炫酷的地图展示效果.丰富的覆盖物图层,更为广大开发人员提供了多种 LBS 检索的能力. 通过这些接口,开发人员能够轻松的訪问百度的 LBS 数据,丰富自己的移 ...