题目大意:一个$N\times N$的阵列,每个格子有$X_{ij}$个调和之音,若每次只能选择走右边或下边,从左上角出发走到右下角,问最多能收集到多少个调和之音?
 
      这题是一道很很很简单的DP题,但可能之前没接触过的同学需要一点脑能量去思考。。如果用最蠢的办法,循环枚举每种选择,求出最大值的话,由于你总共需要往右走$N-1$次,往下走$N-1$次,路径总长度为$2N-2$,根据组合数学,总共有$C_{2N-2}^{N-1}$种走法,想想$C_{1998}^{999}$会是一个多么可怕的数字,不用说这铁定是会超时的,而且铁定会超到地老天荒。怎么办呢?
 
      有的同学可能会考虑:能不能用贪心算法做呢?即每次只有两个选择,我每次都选择最大的那个,那么最终得到的结果是否在整体上是最大的呢?很遗憾这是错的,因为你每次只能往右或往下走,走当前的最大步无法证明走过最小步后,不会产生一条更大的路径。以上两种方案详细的分析参见51Nod - 动态规划入门篇 - 矩阵取数问题(注意先注册登录)。
 
      因此这题非DP不可了,考虑当前格子$X_{ij}$,它要么从$X_{i-1,j}$走过来,要么从$X_{i,j-1}$走过来,因此我只需要做两次循环,给每个格子判断一下从左边来的值更大,还是从上边来的值更大,然后跟这个格子的值相加,这样对于每个格子来说,它的值一定是从左上角到这个格子的最大值。在读入数据的时候就可以计算了。时间复杂度$O(N^2)$,空间复杂度$O(N^2)$。
 #include <stdio.h>

 inline int max(int&a, int&b) {
return a>b?a:b;
} int T, N, mat[][];
int main() {
scanf("%d", &T);
while(T--) {
scanf("%d", &N);
for(int i=; i<=N; i++)
for(int j=; j<=N; j++) {
scanf("%d", mat[i]+j);
mat[i][j]+=max(mat[i-][j], mat[i][j-]);
}
printf("%d\n", mat[N][N]);
}
return ;
}
 
      然后我们再想想,空间复杂度$O(N^2)$其实是没必要哒!因为给每个格子判断只会用到它左边和上边的格子,也就是说只需要保存上一行就行了,判断完这一行的格子就可以覆盖掉了,上两行以上根本没必要保留,因为我们只要求最大值,不是求产生的最大值的路径,因此没必要保存下来(这是ACM中的滚动数组技术)。于是空间复杂度愉快地降到了$O(N)$。
 #include <stdio.h>

 inline int max(int&a, int&b) {
return a>b?a:b;
} int T, N, mat[], x;
int main() {
scanf("%d", &T);
while(T--) {
scanf("%d", &N);
for(int i=; i<=N; i++)
mat[i]=;
for(int i=; i<=N; i++)
for(int j=; j<=N; j++) {
scanf("%d", &x);
mat[j]=max(mat[j-], mat[j])+x;
}
printf("%d\n", mat[N]);
}
return ;
}
 
      比较遗憾的是,现场没有多少人能够做出来这道简单DP题,如果模仿去年新生赛决赛其中一题的难度,即求到终点对某个数$P$取模的最大值的话,估计会更惨。。。。

——by BlackStorm, from herehttp://www.cnblogs.com/BlackStorm/p/5043638.html .

SCNU 2015ACM新生赛决赛【F. Oyk闯机关】解题报告的更多相关文章

  1. SCNU 2015ACM新生赛初赛【1007. ZLM的扑克牌】解题报告

            题目链接详见SCNU 2015新生网络赛 1007. ZLM的扑克牌 .         其实我在想这题的时候,还想过要不要设置求最小的排列,并且对于回文数字的话,可以把扑克牌折起来( ...

  2. SCNU 2015ACM新生赛初赛【1006. 3D打印】解题报告

            题目链接详见SCNU 2015新生网络赛 1006. 3D打印 .出题思路来自codevs 3288. 积木大赛,属于模拟题.         首先我们把“选择从第L部分到第R部分”理 ...

  3. SCNU 2015ACM新生赛初赛【1001~1011】个人解题思路

            题目1001:       大意:已知$n$个角色,$m$种怪物种族,$k$个怪物,给出一组角色编号,编号$P_{i}$的角色能肝死编号$i$的怪物,对于给定的一组怪物编号,为了打通关 ...

  4. SCNU ACM 2016新生赛决赛 解题报告

    新生初赛题目.解题思路.参考代码一览 A. 拒绝虐狗 Problem Description CZJ 去排队打饭的时候看到前面有几对情侣秀恩爱,作为单身狗的 CZJ 表示很难受. 现在给出一个字符串代 ...

  5. 2021广东工业大学新生赛决赛 L-歪脖子树下的灯

    题目:L-歪脖子树下的灯_2021年广东工业大学第11届腾讯杯新生程序设计竞赛(同步赛) (nowcoder.com) 比赛的时候没往dp这方面想(因为之前初赛和月赛数学题太多了啊),因此只往组合数学 ...

  6. 2013级新生程序设计基础竞赛-正式赛 F 异或最大值 解题报告

    F - 异或最大值 Time Limit: 2000/1000MS (Java/Others)      Memory Limit: 128000/64000KB (Java/Others) Subm ...

  7. 安徽师大附中%你赛day6 T3 Hamsters [POI2010]CHO-Hamsters 解题报告

    [POI2010]CHO-Hamsters 题意: 给出n个互不包含的字符串,要求你求出一个最短的字符串S,使得这n个字符串在S中总共至少出现m次,问S最短是多少? 范围: \(1 \le n \le ...

  8. 【HHHOJ】ZJOI2019模拟赛(十三)03.10 解题报告

    点此进入比赛 得分: \(97+0+10=107\) 排名: \(Rank\ 3\) \(Rating\):\(+47\) \(T1\):[HHHOJ187]Hashit(点此看题面) 容易想到可以用 ...

  9. 【HHHOJ】NOIP2018 模拟赛(二十五) 解题报告

    点此进入比赛 得分: \(100+100+20=220\)(\(T1\)打了两个小时,以至于\(T3\)没时间打了,无奈交暴力) 排名: \(Rank\ 8\) \(Rating\):\(+19\) ...

随机推荐

  1. c#操作MangoDB 之MangoDB CSharp Driver驱动详解

    序言 MangoDB CSharp Driver是c#操作mongodb的官方驱动. 官方Api文档:http://api.mongodb.org/csharp/2.2/html/R_Project_ ...

  2. VS 2015相当不错的功能:C#交互窗口

    按照惯例,老周是先吹牛后讲正事.今天就给大伙吹吹这个事. 有网友不知道是不是昨晚喝高了,居然研究起老周来了.实话告诉你,老周没什么好研究的,老周又不是编译器,老周只是一个游离于大善大恶之间的平凡人,说 ...

  3. 基于 getter 和 setter 撸一个简易的MVVM

    Angular 和 Vue 在对Angular的学习中,了解到AngularJS 的两个主要缺点: 对于每一次界面时间,Ajax 或者 timeout,都会进行一个脏检查,而每一次脏检查又会在内部循环 ...

  4. python中的str,unicode和gb2312

    实例1: v1=u '好神奇的问题!?' type(v1)->unicode v1.decode("utf-8")# not work,because v1 is unico ...

  5. FFmpeg学习4:音频格式转换

    前段时间,在学习试用FFmpeg播放音频的时候总是有杂音,网上的很多教程是基于之前版本的FFmpeg的,而新的FFmepg3中audio增加了平面(planar)格式,而SDL播放音频是不支持平面格式 ...

  6. 【DDD/CQRS/微服务架构案例】在Ubuntu 14.04.4 LTS中运行WeText项目的服务端

    在<WeText项目:一个基于.NET实现的DDD.CQRS与微服务架构的演示案例>文章中,我介绍了自己用Visual Studio 2015(C# 6.0 with .NET Frame ...

  7. mailto实现将用户在网页中输入的内容传递到本地邮件客户端

    背景: 想在自己的网站中有这样一个设计: 用户点击提交按钮之后,就会打开本地邮件客户端,并自动将他在输入框中输入的内容作为邮件的内容,像下面这样: mailto可以帮助实现这个功能. 简介: mail ...

  8. 中文分词工具探析(一):ICTCLAS (NLPIR)

    1. 前言 ICTCLAS是张华平在2000年推出的中文分词系统,于2009年更名为NLPIR.ICTCLAS是中文分词界元老级工具了,作者开放出了free版本的源代码(1.0整理版本在此). 作者在 ...

  9. 用C#实现MD5的加密(转载)

    方法一 首先,先简单介绍一下MD5 MD5的全称是message-digest algorithm 5(信息-摘要算法,在90年代初由mit laboratory for computer scien ...

  10. [C#项目开源] MongoDB 可视化管理工具 (2011年10月-至今)

    正文 该项目从2011年10月开始开发,知道现在已经有整整5年了.MongoDB也从一开始的大红大紫到现在趋于平淡. MongoCola这个工具在一开始定位的时候只是一个Windows版本的工具,期间 ...