题目链接:https://cn.vjudge.net/problem/UVA-1347

题意

给出按x坐标排序的几个点。

欲从最左边不回头的走到最右边,然后再返回最左边。

每个点都要被访问,且只能经过一次。

问最小路程是多少。

n<=1000

思路

紫书动规学习中。

首先想到tsp的状压dp(O(n2*2n)),发现n超大,这一定不对。

然后就没有什么正经思路了。

首先发现每个x坐标都不同,且又存在两条路,

那么可以把问题转换一下,问两个人从最左走不同节点到达最右的总路程。

设d(i, j)为走过前i个节点,另一个人现在在j节点时的总路程。

那么有转移方程 d(i, j)=min(d(i+1, j)+dist[i][i+!], d(i+1, i)+dist[j][i+1])

边界条件变成d(0, 0)=0; d(n-1, i)=dist[n-1][i]

顺便一提,动态规划在这里大概写一下经验:

  1. 面对难以分析(转移)的状态,试着规定范围或顺序。

    如dp[i]表示0~i下的代价,dp[i][j]为凸包上点ij连成的线段,分割凸包的从i到j的一部分(规定了上下凸壳)
  2. 通常情况下的区间问题,一般首先通过二分做分析。

    与上面的方法略有相同之处,这里同样可以规定ij的顺序(i在mid左边,j在mid右边),更容易入手。

    二分有着很好的复杂度,我们在不超时的情况下,通过给定的ij顺序甚至可以做任何事情,当然必须考虑合并区间问题。
  3. 在确定状态前,可以分析目标函数来尝试逆推转移方程。

    比如矩阵链乘问题,目标函数是$$ \sum p_i p_k p_j $$

    很明显的发现连加,那么转移方程很可能是dp[i][j]=min(dp[i][k]+dp[k][j]+w[i][j])

    如果是连乘可能是dp[i][j]=min(dp[i][k]dp[k][j]w[i][j])

    如果是单个值,方程可能是dp[i][j]=max(S[i][j], dp[i][k], dp[k+1][j])

    甚至是等差比数列,我们可以通过预处理来算dp

提交过程

AC

代码

#include <cmath>
#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std;
const int maxn=1000+20;
int n, x[maxn], y[maxn];
double data[maxn][maxn], dist[maxn][maxn];
double dp(int i, int j){
if (i==n-1) return dist[j][n-1];
if (data[i][j]>0) return data[i][j]; data[i][j]=min(dp(i+1, i)+dist[j][i+1], dp(i+1, j)+dist[i][i+1]);
return data[i][j];
} int main(void){
while (scanf("%d", &n)==1 && n){
for (int i=0; i<n; i++)
scanf("%d%d", &x[i], &y[i]);
for (int i=0; i<n; i++)
for (int j=i+1; j<n; j++)
dist[i][j]=sqrt((x[i]-x[j])*(x[i]-x[j])+(y[i]-y[j])*(y[i]-y[j]));
memset(data, -1, sizeof(data));
printf("%.2f\n", dp(0, 0));
} return 0;
}
Time Memory Length Lang Submitted
769 None None C++ 5.3.0 2018-08-06 05:10:25

UVA-1347 Tour 动态规划 难以确定的状态的更多相关文章

  1. ACM - 动态规划 - UVA 1347 Tour

    UVA 1347 Tour 题解 题目大意:有 \(n\) 个点,给出点的 \(x\).\(y\) 坐标.找出一条经过所有点一次的回路,从最左边的点出发,严格向右走,到达最右点再严格向左,回到最左点. ...

  2. UVA 1347 Tour 【双调旅行商/DP】

    John Doe, a skilled pilot, enjoys traveling. While on vacation, he rents a small plane and starts vi ...

  3. UVa 1347 Tour

    Tour Time Limit: 3000MS   Memory Limit: Unknown   64bit IO Format: %lld & %llu Description   Joh ...

  4. UVA - 1347 Tour(DP + 双调旅行商问题)

    题意:给出按照x坐标排序的n个点,让我们求出从最左端点到最右短点然后再回来,并且经过所有点且只经过一次的最短路径. 分析:这个题目刘汝佳的算法书上也有详解(就在基础dp那一段),具体思路如下:按照题目 ...

  5. UVA 1347 Tour 双调TSP

    TSP是NP难,但是把问题简化,到最右点之前的巡游路线只能严格向右,到最右边的点以后,返回的时候严格向左,这个问题就可以在多项式时间内求出来了. 定义状态d[i][j]表示一个人在i号点,令一个人在j ...

  6. UVA 1347"Tour"(经典DP)

    传送门 参考资料: [1]:紫书 题意: 欧几里得距离???? 题解: AC代码: #include<bits/stdc++.h> using namespace std; ; int n ...

  7. UVa 1347 (双线程DP) Tour

    题意: 平面上有n个坐标均为正数的点,按照x坐标从小到大一次给出.求一条最短路线,从最左边的点出发到最右边的点,再回到最左边的点.除了第一个和最右一个点其他点恰好只经过一次. 分析: 可以等效为两个人 ...

  8. Tour UVA - 1347

    John Doe, a skilled pilot, enjoys traveling. While on vacation, he rents a small plane and starts vi ...

  9. 【UVa 1347】Tour

    [Link]:https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_probl ...

随机推荐

  1. Unity 动画系统(Mecanim) 术语及翻译 表格

    原文 翻译 Animation Clip 视频片段 Avatar 阿凡达 Retargeting 重定向 Rigging 绑定 skinning 蒙皮 Animator Component 动画组件 ...

  2. CorelDRAW教程:怎样绘制制作箭头流程图?

    箭头流程图主要由矢量图和连接符组成,通过图形之间的顺序阐述的一个过程,应用也是非常广泛,有些软件中会自带流程图,对于CDR这款矢量绘图软件来说,手动制作流程图是简单且高效的.首先CorelDRAW中就 ...

  3. 转载:Vim 配置入门

    转载:Vim 配置入门 原文地址:http://www.ruanyifeng.com/blog/2018/09/vimrc.html 作者: 阮一峰 Vim 是最重要的编辑器之一,主要有下面几个优点. ...

  4. uva 11300 Spreading the Wealth_数学推倒 + 思维

    这道题和负载平衡问题是同一道题, 如果 n<=100n <= 100n<=100 的话是可以用最小费用流来求解的. 但是题中 nnn 最大可达到 10610^6106, 这就需要我们 ...

  5. js数组并集,交集,差集

    js数组并集,交集,差集的计算方式汇总 一. new Set 方式实现 这种方式实现起来比较简单,原理就是参考new Set可以去重的功能 ,关于去重可以点击 https://www.haorooms ...

  6. 【Codeforces Round #483 (Div. 2) C】Finite or not?

    [链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] 有个性质. 如果p/q是分数的最简形式. 那么p/q能化成有限小数. 当且仅当q的质因数分解形式中只有质因子2和5 (且不能出现其他 ...

  7. java内存管理之垃圾回收及JVM调优

    GC(garbage Collector 垃圾收集器)作用:a.内存的动态分配:b.垃圾回收注:Java所承诺的自动内存管理主要是针对对象内存的回收和对象内存的分配. 一.垃圾标记 程序计数器.Jav ...

  8. 第九章 Servlet API

    第九章 Servlet API Servlet API 定义了Servlet和服务器之间的一个标准接口,这使得Servlet具有跨应用服务器的特性,通过使用Servlet API,开发人员不必关心服务 ...

  9. WCF与WEB API区别

  10. OS - 线程和进程的差别

    进程是资源分配的基本单位,又是调度执行的基本单位.比如.用户执行自己的程序,系统就创建一个进程.并为它分配资源,包含各种表.内存空间.磁盘空间.I/O设备等. 然后.把该进程放入进程的就绪队列.进程调 ...