#动态规划#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

相关文章

Spring Boot 与微服务入门实战详细总结

《SpringBoot与微服务入门实战详细总结》本文讲解SpringBoot框架的核心特性如快速构建、自动配置、零XML与微服务架构的定义、演进及优缺点,涵盖开发环境准备和HelloWorld实战... 目录一、Spring Boot 核心概述二、微服务架构详解1. 微服务的定义与演进2. 微服务的优缺点三

RabbitMQ消息总线方式刷新配置服务全过程

《RabbitMQ消息总线方式刷新配置服务全过程》SpringCloudBus通过消息总线与MQ实现微服务配置统一刷新,结合GitWebhooks自动触发更新,避免手动重启,提升效率与可靠性,适用于配... 目录前言介绍环境准备代码示例测试验证总结前言介绍在微服务架构中,为了更方便的向微服务实例广播消息,

一文详解SpringBoot中控制器的动态注册与卸载

《一文详解SpringBoot中控制器的动态注册与卸载》在项目开发中,通过动态注册和卸载控制器功能,可以根据业务场景和项目需要实现功能的动态增加、删除,提高系统的灵活性和可扩展性,下面我们就来看看Sp... 目录项目结构1. 创建 Spring Boot 启动类2. 创建一个测试控制器3. 创建动态控制器注

关于DNS域名解析服务

《关于DNS域名解析服务》:本文主要介绍关于DNS域名解析服务,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录DNS系统的作用及类型DNS使用的协议及端口号DNS系统的分布式数据结构DNS的分布式互联网解析库域名体系结构两种查询方式DNS服务器类型统计构建DNS域

Linux中SSH服务配置的全面指南

《Linux中SSH服务配置的全面指南》作为网络安全工程师,SSH(SecureShell)服务的安全配置是我们日常工作中不可忽视的重要环节,本文将从基础配置到高级安全加固,全面解析SSH服务的各项参... 目录概述基础配置详解端口与监听设置主机密钥配置认证机制强化禁用密码认证禁止root直接登录实现双因素

java向微信服务号发送消息的完整步骤实例

《java向微信服务号发送消息的完整步骤实例》:本文主要介绍java向微信服务号发送消息的相关资料,包括申请测试号获取appID/appsecret、关注公众号获取openID、配置消息模板及代码... 目录步骤1. 申请测试系统2. 公众号账号信息3. 关注测试号二维码4. 消息模板接口5. Java测试

springboot如何通过http动态操作xxl-job任务

《springboot如何通过http动态操作xxl-job任务》:本文主要介绍springboot如何通过http动态操作xxl-job任务的问题,具有很好的参考价值,希望对大家有所帮助,如有错... 目录springboot通过http动态操作xxl-job任务一、maven依赖二、配置文件三、xxl-

HTML5实现的移动端购物车自动结算功能示例代码

《HTML5实现的移动端购物车自动结算功能示例代码》本文介绍HTML5实现移动端购物车自动结算,通过WebStorage、事件监听、DOM操作等技术,确保实时更新与数据同步,优化性能及无障碍性,提升用... 目录1. 移动端购物车自动结算概述2. 数据存储与状态保存机制2.1 浏览器端的数据存储方式2.1.

SpringBoot服务获取Pod当前IP的两种方案

《SpringBoot服务获取Pod当前IP的两种方案》在Kubernetes集群中,SpringBoot服务获取Pod当前IP的方案主要有两种,通过环境变量注入或通过Java代码动态获取网络接口IP... 目录方案一:通过 Kubernetes Downward API 注入环境变量原理步骤方案二:通过

MybatisPlus service接口功能介绍

《MybatisPlusservice接口功能介绍》:本文主要介绍MybatisPlusservice接口功能介绍,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友... 目录Service接口基本用法进阶用法总结:Lambda方法Service接口基本用法MyBATisP