07day2
居然是动规专场。这样不好吧?
采药
【问题描述】
辰辰是个天资聪颖的孩子,他的梦想是成为世界上最伟大的医师。为此,他想拜附近最有威望的医师为师。医师为了判断他的资质,给他出了一个难题。医师把他带到一个到处都是草药的山洞里对他说:"孩子,这个山洞里有一些不同的草药,采每一株都需要一些时间,每一株也有它自身的价值。我会给你一段时间,在这段时间里,你可以采到一些草药。如果你是一个聪明的孩子,你应该可以让采到的草药的总价值最大。"
如果你是辰辰,你能完成这个任务吗?
【输入】
输入的第一行有两个整数 n 和 m,用一个空格隔开。m 代表总共能够用来采药的时间,n 代表山洞里的草药的数目。接下来的 n 行每行包括两个整数,分别表示采摘某株草药的时间 Ti 和这株草药的
价值 Vi。
【输出】
输出包括一行,这一行只包含一个整数,表示在规定的时间内,可以采到的草药的最大总价值。
【输入样例】
3 9
10 10
8 1
1 2
【输出样例】
3
【数据规模】
对于 50%的数据,n,m≤1000;
对于 100%的数据,n,m≤100000,Ti,Vi≤10。
【解题过程】
这个题目描述几乎和 NOIP2006 的那道采药一毛一样以至于我差点写了裸的 01背包。看到数据范围实在吓了一跳。但是要注意这个很强的限制:Ti,Vi≤10。也就是说 Ti*Vi 最多有 121 种取值(姑且算上 0 的情况),那么这 10^6 个物品中大多数都是重复的,可以合并为同一种物品。然后就是多重背包了,二进制拆分就能过。
第一次提交 AC。
方格取数
【问题描述】
给定一个 n×m 的矩阵,记录左上角为(1,1),右下角为(n,m),现在从(1,1)开始取数,每次只能向下或向右移动一个单位,最终到达(n,m),我们把路径上所有的数相乘,结果记为 C。使 C 的结果最大已经不能满足我们了,现在我们想让 C 末尾的零个数最少。
PS. 11000 末尾有三个零,100000100 末尾有两个零。
【输入】
第一行是两个正整数 n 和 m,表示矩阵大小。
接下来 n 行每行 m 个正整数,给出了整个矩阵。
【输出】
一个整数:最少的零的个数。
【输入样例】
3 3
1 2 3
10 5 100
10 8 9
【输出样例】
1
【数据规模】
对 30%的数据有:n,m≤5;
对 100%的数据有:1<n,m≤1000,所有输入数据不超过 32 位整数范围。
【解题过程】
乘积末尾 0 的个数取决于所有乘数质因数分解后 2 和 5 的个数的较小值。但是很难做到同时兼顾两个最小,那就可以用 f(i, j) 表示最少取到的 2 的个数,g(i, j) 表示最少取到的 5 的个数,我们取 f(n, m) 和 g(n, m) 中的较小值就是答案。
一开始有疑问,如果 f(n, m) 走过的路中 5 反而少于 2 呢?假设这个过程中取到的 5 的个数为 x,则 x>=g(n,m),也就是说这种情况在 g(n, m) 中就已经考虑到了;反过来,g(n, m) 取的 2 的个数少于 5 的个数也没有关系。
可以预处理出每个点上的数字分解后有几个2 几个 5.
但是要注意边界条件,把走不到的点设成 INF。
第一次提交 20 分左右。
统计
【问题描述】
对于排列(P1,P2,P3,…Pn),定义(i,j)为逆序对当且仅当 i<j 且 Pi>Pj。统计{1,2,3,…,n}的所有排列中,逆序对数量为 m 的排列个数。
【输入】
仅一行,两个正整数 n,m。
【输出】
仅一个整数,表示满足条件的排列个数对 124567 取模。
【输入样例】
3 1
【输出样例】
2
【数据规模】
对于 30%的数据,有 n≤10;
对于 100%的数据,有 0<n,m≤1000。
【解题过程】
这数据范围简直就是赤裸裸的暗示啊。
用 f(i, j) 表示 1...i 这些数的排列中逆序对有 j 对的情况数,则
f(i, j) = sum{ f(i-1, k), k<=j }
注意必须用前缀和优化。
第一次提交 AC。
07day2的更多相关文章
- 二模07day2解题报告
T1.采药(medic) 有n个草药,要在m的时间内获得最大价值. 乍一看像是01背包,然而数据只能过50分. 考虑数据范围,t<=10,w<=10,所以只有121种草药.考虑多重背包的二 ...
随机推荐
- 深入浅出ES6(十五):子类 Subclassing
作者 Jason Orendorff github主页 https://github.com/jorendorff 在之前的文章<深入浅出ES6(十三):类 Class>中,我们一起深 ...
- PowerMockito(PowerMock用法)
网络上大部分是powermock 的用法, PowerMock有两个重要的注解: –@RunWith(PowerMockRunner.class) –@PrepareForTest( { YourCl ...
- Android:开发环境
一.JAVA SDK(JDK)的安装 http://www.cnblogs.com/tinyphp/p/3664598.html 二.ADT-Bundle 包含了Eclipse.ADT插件和SDK T ...
- ftp下载显示进度
经常用到ftp get命令下载东西,但是遇到大的文件不知道是挂了还是在运行,要是能显示就好了,于是就有了下文... 注: 红色 字体是我敲击的命令 “#” 是注释语 [root@localhost s ...
- ubuntu启动eclipse时出错cannot open display
由于要学习hadoop,就在ubuntu下创建了一个hadoop用户,但是eclipse是在naomi用户下装的,在root和naomi用户下都能正常启动,但是一旦切换到hadoop用户,试着启动ec ...
- http 服务
今天把一个功能模块做成了http服务,这还是第一次写http服务,纪录下来. package com.chuntent.itemsearch; import java.io.BufferedReade ...
- R语言学习笔记——Base Graphics
做exploratory data annalysis的作业,差点被虐死了,R从头开始,边做边学,最后搞到一点多才弄完,还有一个图怎么画都不对,最后发现是数据读取的时候有问题. 用来画图的数据来自:h ...
- Maven+Spring+MVC结构中,jetty/tomcat是如何启动项目的[转]
针对maven配置的Spring+MVC项目,我们用Maven自带的jetty和tomcat插件进行调试,这很方便.但是调试时,这些插件所启动的web服务器,是如何来将我们的工程作为一个web项目启动 ...
- struts配置。泪奔...
说多了都是泪啊,配置一个环境一天才搞定.不错the requested resource (/login) is not available in struts,就是找不到什么什么class.亦或th ...
- 南阳理工ACM Skiing问题
描述 Michael喜欢滑雪百这并不奇怪, 因为滑雪的确很刺激.可是为了获得速度,滑的区域必须向下倾斜,而且当你滑到坡底,你不得不再次走上坡或者等待升降机来载你.Michael想知道载一个区域中最长底 ...