`

HDU 2571 命运 .

DP 
阅读更多

命运

Time Limit : 2000/1000ms (Java/Other)   Memory Limit : 32768/32768K (Java/Other)
Total Submission(s) : 9   Accepted Submission(s) : 4

Font: Times New Roman | Verdana | Georgia

Font Size:

Problem Description

穿过幽谷意味着离大魔王lemon已经无限接近了!
可谁能想到,yifenfei在斩杀了一些虾兵蟹将后,却再次面临命运大迷宫的考验,这是魔王lemon设下的又一个机关。要知道,不论何人,若在迷宫中被困1小时以上,则必死无疑!
可怜的yifenfei为了去救MM,义无返顾地跳进了迷宫。让我们一起帮帮执着的他吧!
命运大迷宫可以看成是一个两维的方格阵列,如下图所示:
 
yifenfei一开始在左上角,目的当然是到达右下角的大魔王所在地。迷宫的每一个格子都受到幸运女神眷恋或者痛苦魔王的诅咒,所以每个格子都对应一个值,走到那里便自动得到了对应的值。
现在规定yifenfei只能向右或者向下走,向下一次只能走一格。但是如果向右走,则每次可以走一格或者走到该行的列数是当前所在列数倍数的格子,即:如果当前格子是(x,y),下一步可以是(x+1,y),(x,y+1)或者(x,y*k) 其中k>1。
为了能够最大把握的消灭魔王lemon,yifenfei希望能够在这个命运大迷宫中得到最大的幸运值。

Input

输入数据首先是一个整数C,表示测试数据的组数。
每组测试数据的第一行是两个整数n,m,分别表示行数和列数(1<=n<=20,10<=m<=1000);
接着是n行数据,每行包含m个整数,表示n行m列的格子对应的幸运值K ( |k|<100 )。

Output

请对应每组测试数据输出一个整数,表示yifenfei可以得到的最大幸运值。

Sample Input

1 3 8 9 10 10 10 10 -10 10 10 10 -11 -1 0 2 11 10 -20 -11 -11 10 11 2 10 -10 -10

Sample Output

52

Author

yifenfei

Source

ACM程序设计期末考试081230
 
呢类DP题目我地呢度通常称为数塔题,因为基本上都系同一个模型只不过走法多左一种甘解,都几容易写出状态转移方程{=   =+}。
注意题目提到有三种走法:
假设当前位置为(x, y), 矩阵大小为[n][ m],
1、可以走向(x + 1 ,y)。
2、可以走向(x, y + 1)。(第一次测试果阵发觉答案错左,原来漏了呢种可能)
3、可以走向(x, y * k)其中y * k <= m且k > 1。(无左呢个就系数塔问题鸟)
 
所以状态转移方程就系:
dp[x][y] = Max(dp[x - 1][y], dp[x][y - 1], {dp[x][y / k] | 1 < k <= y})
 
我写法类似最短路既松弛技术,即系顺推用一个临时数组储存当前比较值,由当前点出发有(1 + 1 + k)条路每条路都松弛一下,时间复杂
度都相似,大概O(n*m*∑k)吧。
 
下面写代码{=     =}
00762067 2011-07-20 14:19:17 Accepted 1009 15 MS 388 KB Visual C++ 10SGetEternal{(。)
#include <iostream>
using namespace std;

#define XMAX 22
#define YMAX 1001
#define INFI ((1<<31) - 1)

int n, m, map[XMAX][YMAX], ts[XMAX][YMAX];

void print(int *arr, int siz)
{
 int i;

 for (i = 1; i <= siz; i++)
  printf(arr[i] == -INFI?"-INFI ":"%6d ", arr[i]);
 putchar('\n');
}

void init()
{
 int i,j;
 
 for (i = 1; i <= n; i++)
  for (j = 1; j <= m; j++)
   ts[i][j] = -INFI;
}

int dp()
{
 int i, j, k;

 ts[1][1] = 0;
 for (i = 1; i <= n; i++)
  for (j = 1; j <= m; j++)
  {
   ts[i][j] += map[i][j];
   for (k = 2; k * j <= m; k++)
    if (ts[i][j] > ts[i][k * j])
     ts[i][k * j] = ts[i][j];
   if (i < n && ts[i][j] > ts[i + 1][j]) ts[i + 1][j] = ts[i][j];
   if (j < m && ts[i][j] > ts[i][j + 1]) ts[i][j + 1] = ts[i][j];
  }
 return ts[n][m];
}

int main()
{
 int C, i, j;

 scanf("%d", &C);
 while (C--)
 {
  scanf("%d%d", &n, &m);
  for (i = 1; i <= n; i++)
   for (j = 1; j <= m; j++)
    scanf("%d", map[i] + j);
#if 0
  for (i = 1; i <= n; i++)
   print(map[i], m);
#endif
  init();
#if 0
  for (i = 1; i <= n; i++)
   print(ts[i], m);
#endif
  printf("%d\n", dp());
#if 0
  for (i = 1; i <= n; i++)
   print(ts[i], m);
#endif
 }

 return 0;
}

 

 
多谢收睇{^ _____^}
分享到:
评论

相关推荐

    算法-命运(HDU-2571)(包含源程序).rar

    标题中的“算法-命运(HDU-2571)”是一个编程竞赛题目,通常来自于各大在线编程平台,如HDU(杭州电子科技大学在线评测系统)等。这类问题旨在测试和提升参赛者的算法设计和编程能力。从描述来看,这个压缩包包含了...

    DP46题.doc

    8. **命运**(题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2571) 这是一个二维背包问题,状态方程是:`sum[i][j]=max{sum[i-1][j], sum[i][k]}+v[i][j]`,其中`1,`k`是`j`的因子。 9. **Monkey And ...

    HDU 专题分类(2013年8月)

    FATE (命运) - **问题描述**:可能是基于概率的决策问题,需要在不确定性中做出最佳选择。 - **算法应用**:期望值计算,结合概率论解决决策问题。 #### 3. 小明系列故事——买年货 - **问题描述**:涉及购物清单...

    PhD_Thesis_Cristina_Pinneri.pdf

    PhD_Thesis_Cristina_Pinneri

    Git知识学习(尚硅谷)

    Git知识学习(尚硅谷)

    套筒机械加工工艺规程制订设计.rar

    套筒机械加工工艺规程制订设计.rar

    The First Adventures on Differential Geometry 9789811296178.pdf

    The First Adventures on Differential Geometry 9789811296178

    汽车防误踏油门机构的设计.zip

    汽车防误踏油门机构的设计.zip

    汽车离合器设计.zip

    汽车离合器设计.zip

    基于SpringBoot的文学创作社交论坛(源码+数据库+万字文档+ppt)533

    基于SpringBoot的文学创作社交论坛,系统包含两种角色:管理员、用户主要功能如下。 【用户功能】 1. **首页:** 浏览社交论坛的主要信息。 2. **火车信息:** 阅读和浏览用户发布的文学创作。 3. **公告资讯:** 查看社交论坛发布的重要通知和公告。 4. **后台管理:** - **首页:** 进行后台管理相关操作。 - **个人中心:** 管理个人信息,查看火车票订购历史等。 - **车票预订管理:** 预订文学创作,选择特定的创作者或主题。 - **车票退票管理:** 处理用户对已预订文学创作的退票请求。 5. **个人中心:** 管理个人信息。 【管理员功能】 1. **首页:** 查看社交论坛整体概况。 2. **个人中心:** 修改密码、管理个人信息。 3. **用户管理:** 审核和管理注册用户的信息。 4. **火车类型管理:** 管理文学创作的分类信息。 5. **火车信息管理:** 监管和管理社交论坛上的文学创作信息。 6. **车票预订管理:** 查看和管理用户的文学创作预订情况。 7. **车票退票管理:** 处理用户对已预订文学创作的退票请求。 8. **系统管理:** - **公告资讯:** 发布、编辑和删除系统的通知和公告。 - **关于我们:** 编辑和更新社交论坛的介绍。 - **系统简介:** 提供社交论坛的简要介绍。 - **轮播图管理:** 管理社交论坛首页的轮播图。 二、项目技术 编程语言:Java 数据库:MySQL 项目管理工具:Maven 前端技术:Vue 后端技术:SpringBoot 三、运行环境 操作系统:Windows、macOS都可以 JDK版本:JDK1.8以上都可以 开发工具:IDEA、Ecplise、Myecplise都可以 数据库

    数控铣床主轴箱设计.zip

    数控铣床主轴箱设计.zip

    某电镀废水工艺流程及平面布置图.zip

    某电镀废水工艺流程及平面布置图.zip

    joblib-0.9.0b4-py2.7.egg

    该资源为joblib-0.9.0b4-py2.7.egg,欢迎下载使用哦!

    价值60元的带会员和后台版的域名防红1.19最新免授权开心版

    管理会员制度渠道,掌管多种服务,黑白名单管理邮箱配置生成提醒发送对接易支付进行交易,订单列表,带有各种短网址功能提供接口对接,实现短网址+防红两不误,可自定义多中转域名,自动识别安全网址各种防红数据后台可显,自定义跳转网站 用户端android-ios 会员制度享受,自定义跳转网站,在线充值,我的生成,在线生成,为你的网址提供保护短网址列表接口文档数据显示,编辑我的生成 防红效果全网 在短网址与防红的前提下,为你的网站提供SEO服务以及腾讯相关网站检测的优化 贴吧+短视频平台+ios+android+pc皆正常 安装:上传源码,访问安装。提示授权时,随意填写 6位数字即可

    joblib-0.9.0b3.tar.gz

    该资源为joblib-0.9.0b3.tar.gz,欢迎下载使用哦!

    实时操作系统毕业设计项目内含说明书.zip

    实时操作系统毕业设计项目内含说明书.zip

    python相关学习资源,python

    python

    塑料瓶自动封口机设计.rar

    塑料瓶自动封口机设计.rar

    CarPlay 系统功能介绍,比较专业的文档,告诉我们开发Carplay的时候需要遵循的规则

    内容概要:本文介绍了苹果公司在WWDC19上发布的CarPlay系统的最新进展,主要包括四个方面的改进:不规则形状显示屏支持、多屏显示支持、动态屏幕尺寸调整以及“嘿,Siri”语音助手集成。不规则形状显示屏支持允许开发者为CarPlay定义交互区域,确保内容适应各种非矩形屏幕。多屏显示支持使车辆可以在多个屏幕上同时展示CarPlay界面,如中心控制台和仪表盘,提供导航、音乐播放等不同内容,并支持独立的夜间模式。动态屏幕尺寸调整功能让CarPlay界面可以实时调整大小,以适应不同的驾驶环境或用户需求。最后,“嘿,Siri”功能让用户可以通过语音唤醒Siri,即使在播放音乐时也能无缝交互,系统内置了持续的回声消除和降噪处理,确保语音识别的准确性。; 适合人群:汽车制造商、软件开发者以及对车载信息系统感兴趣的科技爱好者。; 使用场景及目标:①汽车制造商可以根据新的CarPlay特性优化车内娱乐和导航系统的用户体验;②开发者可以利用这些新特性创建更加丰富的车载应用程序;③科技爱好者可以了解最新的车载技术发展趋势。; 其他说明:文档详细描述了CarPlay系统的技术细节,包括语音活动检测器、关键词检测器、回声消除和降噪等功能的工作原理,以及车辆系统的要求,如始终开启的麦克风输入流处理、连续回声消除和降噪等。更多相关信息可参考苹果开发者网站。

    蓝桥杯第十六届省赛真题!

    内容概要:本文档为第十六届蓝桥杯单片机设计与开发项目省赛的程序设计试题说明,面向大学组。文档详细规定了比赛的基本要求、硬件配置、功能描述、性能要求、输出控制、显示功能、按键功能及初始状态。参赛者需要使用指定的单片机竞赛实训平台,完成环境温度、光强、物体运动状态的检测,并通过数码管、LED指示灯、继电器等实现相应的数据显示、状态指示与控制功能。所有程序需在Keil环境下开发,并按要求提交工程文件。 适合人群:具有单片机编程基础的大专院校学生或相关专业技术人员。 使用场景及目标:①掌握单片机编程技能,熟悉传感器数据采集与处理;②学会通过数码管、LED、继电器等实现人机交互界面的设计与实现;③提高对硬件资源的有效利用能力,确保系统的实时性和稳定性。 阅读建议:此资源旨在帮助参赛者理解比赛规则和技术要求,建议仔细阅读各项功能的具体实现细节,特别注意硬件配置、性能指标以及提交规范的要求。同时,在实际操作中要严格按照文档中的规定进行开发和测试,确保作品符合评分标准。

Global site tag (gtag.js) - Google Analytics