#动态规划#SP703 codevs 2182 1383 CH 5102 Mobile Service 移动服务

2024-02-11 06:08

本文主要是介绍#动态规划#SP703 codevs 2182 1383 CH 5102 Mobile Service 移动服务,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目

有三个移动服务员,最初分别在位置1,2,3处。
如果某个位置(用一个整数表示)有一个请求,那么公司必须指派某名员工赶到那个地方去。某一时刻只有一个员工能移动,且不允许在同样的位置出现两个员工。从 p p p q q q移动一个员工,需要花费 c ( p , q ) c(p,q) c(p,q)。求最小花费。


分析

用动态规划,但是普通的动态规划不仅时间超时,空间也无法满足,所以需要优化,可以发现员工应该在的位置其实是冗余,所以说可以优化为

f[x][i][j]=f[x][j][i]=min(f[x][i][j],f[x^1][i][j]+c[ls][y]);//从上一个点赶到这一个点f[x][ls][j]=f[x][j][ls]=min(f[x][j][ls],f[x^1][i][j]+c[i][y]);//从i点赶到这一个点f[x][i][ls]=f[x][ls][i]=min(f[x][i][ls],f[x^1][i][j]+c[j][y]);//从j点赶到这一个点

时间复杂度 O ( m n 2 ) O(mn^2) O(mn2)


代码

#include <cstdio>
#include <cstring>
int n,m,ls,y,f[2][201][201],c[201][201];
int in(){int ans=0; char c=getchar();while (c<48||c>57) c=getchar();while (c>47&&c<58) ans=ans*10+c-48,c=getchar();return ans;
}
int min(int a,int b){return (a<b)?a:b;}
int main(){n=in(); m=in(); memset(f[0],127/3,sizeof(f[0]));for (int i=1;i<=n;i++)for (int j=1;j<=n;j++) c[i][j]=in();ls=in(); int ans=f[0][0][0],x=0;f[0][1][2]=f[0][2][1]=c[3][ls]; //初始化f[0][1][3]=f[0][3][1]=c[2][ls];f[0][2][3]=f[0][3][2]=c[1][ls];while (--m){x^=1; memset(f[x],127/3,sizeof(f[x])); y=in();for (int i=1;i<=n;i++)for (int j=1;j<=n;j++)if (i!=j&&i!=ls&&j!=ls)//动态规划(滚动数组)f[x][i][j]=f[x][j][i]=min(f[x][i][j],f[x^1][i][j]+c[ls][y]),f[x][ls][j]=f[x][j][ls]=min(f[x][j][ls],f[x^1][i][j]+c[i][y]),f[x][i][ls]=f[x][ls][i]=min(f[x][i][ls],f[x^1][i][j]+c[j][y]);ls=y;}for (int i=1;i<=n;i++)for (int j=1;j<=n;j++) ans=min(ans,f[x][i][j]);return !printf("%d",ans);
}

这篇关于#动态规划#SP703 codevs 2182 1383 CH 5102 Mobile Service 移动服务的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

sysmain服务可以禁用吗? 电脑sysmain服务关闭后的影响与操作指南

《sysmain服务可以禁用吗?电脑sysmain服务关闭后的影响与操作指南》在Windows系统中,SysMain服务(原名Superfetch)作为一个旨在提升系统性能的关键组件,一直备受用户关... 在使用 Windows 系统时,有时候真有点像在「开盲盒」。全新安装系统后的「默认设置」,往往并不尽编

Python 基于http.server模块实现简单http服务的代码举例

《Python基于http.server模块实现简单http服务的代码举例》Pythonhttp.server模块通过继承BaseHTTPRequestHandler处理HTTP请求,使用Threa... 目录测试环境代码实现相关介绍模块简介类及相关函数简介参考链接测试环境win11专业版python

Nginx中配置使用非默认80端口进行服务的完整指南

《Nginx中配置使用非默认80端口进行服务的完整指南》在实际生产环境中,我们经常需要将Nginx配置在其他端口上运行,本文将详细介绍如何在Nginx中配置使用非默认端口进行服务,希望对大家有所帮助... 目录一、为什么需要使用非默认端口二、配置Nginx使用非默认端口的基本方法2.1 修改listen指令

解决Nginx启动报错Job for nginx.service failed because the control process exited with error code问题

《解决Nginx启动报错Jobfornginx.servicefailedbecausethecontrolprocessexitedwitherrorcode问题》Nginx启... 目录一、报错如下二、解决原因三、解决方式总结一、报错如下Job for nginx.service failed bec

SysMain服务可以关吗? 解决SysMain服务导致的高CPU使用率问题

《SysMain服务可以关吗?解决SysMain服务导致的高CPU使用率问题》SysMain服务是超级预读取,该服务会记录您打开应用程序的模式,并预先将它们加载到内存中以节省时间,但它可能占用大量... 在使用电脑的过程中,CPU使用率居高不下是许多用户都遇到过的问题,其中名为SysMain的服务往往是罪魁

浅谈MySQL的容量规划

《浅谈MySQL的容量规划》进行MySQL的容量规划是确保数据库能够在当前和未来的负载下顺利运行的重要步骤,容量规划包括评估当前资源使用情况、预测未来增长、调整配置和硬件资源等,感兴趣的可以了解一下... 目录一、评估当前资源使用情况1.1 磁盘空间使用1.2 内存使用1.3 CPU使用1.4 网络带宽二、

解决若依微服务框架启动报错的问题

《解决若依微服务框架启动报错的问题》Invalidboundstatement错误通常由MyBatis映射文件未正确加载或Nacos配置未读取导致,需检查XML的namespace与方法ID是否匹配,... 目录ruoyi-system模块报错报错详情nacos文件目录总结ruoyi-systnGLNYpe

Nginx进行平滑升级的实战指南(不中断服务版本更新)

《Nginx进行平滑升级的实战指南(不中断服务版本更新)》Nginx的平滑升级(也称为热升级)是一种在不停止服务的情况下更新Nginx版本或添加模块的方法,这种升级方式确保了服务的高可用性,避免了因升... 目录一.下载并编译新版Nginx1.下载解压2.编译二.替换可执行文件,并平滑升级1.替换可执行文件

把Python列表中的元素移动到开头的三种方法

《把Python列表中的元素移动到开头的三种方法》在Python编程中,我们经常需要对列表(list)进行操作,有时,我们希望将列表中的某个元素移动到最前面,使其成为第一项,本文给大家介绍了把Pyth... 目录一、查找删除插入法1. 找到元素的索引2. 移除元素3. 插入到列表开头二、使用列表切片(Lis

go动态限制并发数量的实现示例

《go动态限制并发数量的实现示例》本文主要介绍了Go并发控制方法,通过带缓冲通道和第三方库实现并发数量限制,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录带有缓冲大小的通道使用第三方库其他控制并发的方法因为go从语言层面支持并发,所以面试百分百会问到