动态规划--uva1025 城市里的间谍

2024-01-14 06:48

本文主要是介绍动态规划--uva1025 城市里的间谍,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

影响决策的因素有当前时间t和所处车站,所以dp[t][n],2维。

求等待最短时间,即dp[t][n]

决策有3个,等待1分钟,向右坐火车,向左坐火车。


#include <iostream>

#include <cstdio>

#include <cstring>

using namespacestd;

const int maxn =255;

const int INF =1 << 25;


int dis[55];

int d[maxn],e[maxn];

bool has_train[maxn][55][2];

int dp[maxn][55];

int n,t,m1,m2;

void f()

{

    for (int i =1; i <= n -1; i ++) {

        dp[t][i] =INF;

    }

    dp[t][n] =0;

    for (int i =t - 1; i >=0; i --) {

        for (int j =1; j <= n; j ++) {

            dp[i][j] =dp[i + 1][j] +1;

            if(j <n && has_train[i][j][0] && i +dis[j] <= t)

            {

                dp[i][j] =min(dp[i][j],dp[i +dis[j]][j + 1]);

            }

            if(j >1 && has_train[i][j][1] && i +dis[j - 1] <=t)

            {

                dp[i][j] =min(dp[i][j],dp[i +dis[j - 1]][j -1]);

            }

        }

    }

}

int main()

{

    int kce =0;

    while (cin >>n && n) {

        memset(dis,0, sizeof(dis));

        memset(has_train,0, sizeof(has_train));

        memset(d,0, sizeof(d));

        memset(e,0, sizeof(e));

        memset(dp,0, sizeof(dp));

        cin >>t;

        for (int i =1; i <= n -1; i ++) {

            scanf("%d",&dis[i]);

        }

        cin >>m1;

        for (int i =1; i <= m1; i ++) {

            scanf("%d",&d[i]);

        }

        cin >>m2;

        for (int i =1; i <= m2; i ++) {

            scanf("%d",&e[i]);

        }

        for (int i =1; i <= m1; i ++) {

            int tmp =d[i];

            for (int j =1; j < n; j ++) {

                has_train[tmp][j][0] =true;

              //  cout << "when time  " << tmp<< " at station " << j <<" has train to right" << endl;

                tmp += dis[j];

            }

        }

        for (int i =1; i <= m2; i ++) {

            int tmp =e[i];

            for (int j =n; j > 1; j --) {

                has_train[tmp][j][1] =true;

               //  cout << "when time  " << tmp<< " at station " << j <<" has train to left" << endl;

                tmp += dis[j -1];

            }

        }

        f();


        cout <<"Case Number " << ++kce <<": " ;

        if (dp[0][1] >= INF) {

            cout <<"impossible\n";

        }

        elsecout << dp[0][1] <<endl;

            }

    return0;

}


这篇关于动态规划--uva1025 城市里的间谍的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

基于Canvas的Html5多时区动态时钟实战代码

《基于Canvas的Html5多时区动态时钟实战代码》:本文主要介绍了如何使用Canvas在HTML5上实现一个多时区动态时钟的web展示,通过Canvas的API,可以绘制出6个不同城市的时钟,并且这些时钟可以动态转动,每个时钟上都会标注出对应的24小时制时间,详细内容请阅读本文,希望能对你有所帮助...

Vue中动态权限到按钮的完整实现方案详解

《Vue中动态权限到按钮的完整实现方案详解》这篇文章主要为大家详细介绍了Vue如何在现有方案的基础上加入对路由的增、删、改、查权限控制,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、数据库设计扩展1.1 修改路由表(routes)1.2 修改角色与路由权限表(role_routes)二、后端接口设计

前端 CSS 动态设置样式::class、:style 等技巧(推荐)

《前端CSS动态设置样式::class、:style等技巧(推荐)》:本文主要介绍了Vue.js中动态绑定类名和内联样式的两种方法:对象语法和数组语法,通过对象语法,可以根据条件动态切换类名或样式;通过数组语法,可以同时绑定多个类名或样式,此外,还可以结合计算属性来生成复杂的类名或样式对象,详细内容请阅读本文,希望能对你有所帮助...

Nginx实现动态封禁IP的步骤指南

《Nginx实现动态封禁IP的步骤指南》在日常的生产环境中,网站可能会遭遇恶意请求、DDoS攻击或其他有害的访问行为,为了应对这些情况,动态封禁IP是一项十分重要的安全策略,本篇博客将介绍如何通过NG... 目录1、简述2、实现方式3、使用 fail2ban 动态封禁3.1 安装 fail2ban3.2 配

Vue3中的动态组件详解

《Vue3中的动态组件详解》本文介绍了Vue3中的动态组件,通过`component:is=动态组件名或组件对象/component`来实现根据条件动态渲染不同的组件,此外,还提到了使用`markRa... 目录vue3动态组件动态组件的基本使用第一种写法第二种写法性能优化解决方法总结Vue3动态组件动态

Android 悬浮窗开发示例((动态权限请求 | 前台服务和通知 | 悬浮窗创建 )

《Android悬浮窗开发示例((动态权限请求|前台服务和通知|悬浮窗创建)》本文介绍了Android悬浮窗的实现效果,包括动态权限请求、前台服务和通知的使用,悬浮窗权限需要动态申请并引导... 目录一、悬浮窗 动态权限请求1、动态请求权限2、悬浮窗权限说明3、检查动态权限4、申请动态权限5、权限设置完毕后

Java使用POI-TL和JFreeChart动态生成Word报告

《Java使用POI-TL和JFreeChart动态生成Word报告》本文介绍了使用POI-TL和JFreeChart生成包含动态数据和图表的Word报告的方法,并分享了实际开发中的踩坑经验,通过代码... 目录前言一、需求背景二、方案分析三、 POI-TL + JFreeChart 实现3.1 Maven

Java导出Excel动态表头的示例详解

《Java导出Excel动态表头的示例详解》这篇文章主要为大家详细介绍了Java导出Excel动态表头的相关知识,文中的示例代码简洁易懂,具有一定的借鉴价值,有需要的小伙伴可以了解下... 目录前言一、效果展示二、代码实现1.固定头实体类2.动态头实现3.导出动态头前言本文只记录大致思路以及做法,代码不进

vue基于ElementUI动态设置表格高度的3种方法

《vue基于ElementUI动态设置表格高度的3种方法》ElementUI+vue动态设置表格高度的几种方法,抛砖引玉,还有其它方法动态设置表格高度,大家可以开动脑筋... 方法一、css + js的形式这个方法需要在表格外层设置一个div,原理是将表格的高度设置成外层div的高度,所以外层的div需要

SpringBoot实现动态插拔的AOP的完整案例

《SpringBoot实现动态插拔的AOP的完整案例》在现代软件开发中,面向切面编程(AOP)是一种非常重要的技术,能够有效实现日志记录、安全控制、性能监控等横切关注点的分离,在传统的AOP实现中,切... 目录引言一、AOP 概述1.1 什么是 AOP1.2 AOP 的典型应用场景1.3 为什么需要动态插