紫书P269-uva1347题解,结合紫书解析加入了一些个人理解

2023-11-20 17:32

本文主要是介绍紫书P269-uva1347题解,结合紫书解析加入了一些个人理解,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

该题在vjudge上的链接
在紫书的动态规划那一节看到了这道题。结合刘汝佳的解析,在代码里加了一些个人的理解,已经提交UVA通过。

//将问题看做两个人从起点出发,不能走重复的点,计算两个人到达终点时走过的距离和
#include <bits/stdc++.h>
#define mem(a, b) memset(a, b, sizeof(a))
#define scf(a) scanf("%d", &a)
#define scf2(a, b) scanf("%d%d", &a, &b)
using namespace std;struct point
{int x, y;
} p[1001];//dp[i][j]表示一个人在i,一个人在j,二者到终点还差的距离和,且1到i的点已经全部走过
//因为dp[i][j]==dp[j][i],所以规定i>j,因为两人不能在同一个点,所以i!=j
//状态方程为dp[i][j]=min(dp[i+1][j]+dist(i,i+1),dp[i+1][i]+dist(j,i+1));
//一种是让处于i的人走,一种是让处于j的人走,且下一步必须走到i+1,不能走其他地方
//对于这种走法是否存在漏解的说明:这种走法依然能遍历到所有二者位置的状态,
//且在遍历dp[i][j]之前,dp[x>=i][y>=j]的结果都已确定(见cal函数的递归实现),可以保证dp[i][j]的正确性
double dp[1001][1001];double dist(int a, int b) //传入两个点的下标,计算二者距离
{int dx = p[a].x - p[b].x, dy = p[a].y - p[b].y;return sqrt(dx * dx + dy * dy);
}double cal(int i, int j) //计算并返回dp[i][j]的值,递归实现
{if (dp[i][j] != 0)return dp[i][j];//在两个人中选取一个人走到i+1//走了之后要加上dist(o->e)的距离dp[i][j] = min(cal(i + 1, j) + dist(i, i + 1), cal(i + 1, i) + dist(j, i + 1));return dp[i][j];
}int main()
{mem(dp, 0);int n;while (scf(n)!=EOF){mem(dp,0);for (int i = 1; i <= n; i++){scf2(p[i].x, p[i].y);}double dis = dist(n, n - 1); //n到n-1的距离,减少重复计算/*  计算一个人处于n-1,另一个人处于j时,距离终点还有多远,因为dp[i][j](i>j)表示i内的点都已经走过,所以dp[n-1][j]就只剩下了n可以走,所以距离是唯一确定的也就是n-1到n的距离加上j到n的距离*/for (int j = 1; j < n - 1; j++){dp[n - 1][j] = dis + dist(j, n);}printf("%.2lf\n", cal(2, 1) + dist(1, 2));}return 0;
}/*样例数据3
1 1
2 3
3 1
4
1 1
2 3
3 1
4 2*/

这篇关于紫书P269-uva1347题解,结合紫书解析加入了一些个人理解的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/396291

相关文章

Spring Boot 结合 WxJava 实现文章上传微信公众号草稿箱与群发

《SpringBoot结合WxJava实现文章上传微信公众号草稿箱与群发》本文将详细介绍如何使用SpringBoot框架结合WxJava开发工具包,实现文章上传到微信公众号草稿箱以及群发功能,... 目录一、项目环境准备1.1 开发环境1.2 微信公众号准备二、Spring Boot 项目搭建2.1 创建

nginx -t、nginx -s stop 和 nginx -s reload 命令的详细解析(结合应用场景)

《nginx-t、nginx-sstop和nginx-sreload命令的详细解析(结合应用场景)》本文解析Nginx的-t、-sstop、-sreload命令,分别用于配置语法检... 以下是关于 nginx -t、nginx -s stop 和 nginx -s reload 命令的详细解析,结合实际应

MyBatis中$与#的区别解析

《MyBatis中$与#的区别解析》文章浏览阅读314次,点赞4次,收藏6次。MyBatis使用#{}作为参数占位符时,会创建预处理语句(PreparedStatement),并将参数值作为预处理语句... 目录一、介绍二、sql注入风险实例一、介绍#(井号):MyBATis使用#{}作为参数占位符时,会

SpringBoot结合Docker进行容器化处理指南

《SpringBoot结合Docker进行容器化处理指南》在当今快速发展的软件工程领域,SpringBoot和Docker已经成为现代Java开发者的必备工具,本文将深入讲解如何将一个SpringBo... 目录前言一、为什么选择 Spring Bootjavascript + docker1. 快速部署与

深入理解Go语言中二维切片的使用

《深入理解Go语言中二维切片的使用》本文深入讲解了Go语言中二维切片的概念与应用,用于表示矩阵、表格等二维数据结构,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起学习学习吧... 目录引言二维切片的基本概念定义创建二维切片二维切片的操作访问元素修改元素遍历二维切片二维切片的动态调整追加行动态

PostgreSQL的扩展dict_int应用案例解析

《PostgreSQL的扩展dict_int应用案例解析》dict_int扩展为PostgreSQL提供了专业的整数文本处理能力,特别适合需要精确处理数字内容的搜索场景,本文给大家介绍PostgreS... 目录PostgreSQL的扩展dict_int一、扩展概述二、核心功能三、安装与启用四、字典配置方法

深度解析Java DTO(最新推荐)

《深度解析JavaDTO(最新推荐)》DTO(DataTransferObject)是一种用于在不同层(如Controller层、Service层)之间传输数据的对象设计模式,其核心目的是封装数据,... 目录一、什么是DTO?DTO的核心特点:二、为什么需要DTO?(对比Entity)三、实际应用场景解析

从原理到实战深入理解Java 断言assert

《从原理到实战深入理解Java断言assert》本文深入解析Java断言机制,涵盖语法、工作原理、启用方式及与异常的区别,推荐用于开发阶段的条件检查与状态验证,并强调生产环境应使用参数验证工具类替代... 目录深入理解 Java 断言(assert):从原理到实战引言:为什么需要断言?一、断言基础1.1 语

深度解析Java项目中包和包之间的联系

《深度解析Java项目中包和包之间的联系》文章浏览阅读850次,点赞13次,收藏8次。本文详细介绍了Java分层架构中的几个关键包:DTO、Controller、Service和Mapper。_jav... 目录前言一、各大包1.DTO1.1、DTO的核心用途1.2. DTO与实体类(Entity)的区别1

Java中的雪花算法Snowflake解析与实践技巧

《Java中的雪花算法Snowflake解析与实践技巧》本文解析了雪花算法的原理、Java实现及生产实践,涵盖ID结构、位运算技巧、时钟回拨处理、WorkerId分配等关键点,并探讨了百度UidGen... 目录一、雪花算法核心原理1.1 算法起源1.2 ID结构详解1.3 核心特性二、Java实现解析2.