07day2

时间:2022-06-04 21:30:53

居然是动规专场。这样不好吧?

 

采药

【问题描述】

辰辰是个天资聪颖的孩子,他的梦想是成为世界上最伟大的医师。为此,他想拜附近最有威望的医师为师。医师为了判断他的资质,给他出了一个难题。医师把他带到一个到处都是草药的山洞里对他说:"孩子,这个山洞里有一些不同的草药,采每一株都需要一些时间,每一株也有它自身的价值。我会给你一段时间,在这段时间里,你可以采到一些草药。如果你是一个聪明的孩子,你应该可以让采到的草药的总价值最大。"

如果你是辰辰,你能完成这个任务吗?

【输入】

输入的第一行有两个整数 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的更多相关文章

  1. 二模07day2解题报告

    T1.采药(medic) 有n个草药,要在m的时间内获得最大价值. 乍一看像是01背包,然而数据只能过50分. 考虑数据范围,t<=10,w<=10,所以只有121种草药.考虑多重背包的二 ...

随机推荐

  1. &lbrack;CentOs&rsqb;ip操作

    摘要 在虚机里面安装好centos之后,需要知道centos的ip,方便以后连接时使用. 查看ip命令 命令 ifconfig 能查看到信息,说明已经配置过了,如果没配置过,可以通过下面的方式进行配置 ...

  2. 感冒了~ vs中py和vb实现一个小算法

    1+1*2+1*2*3+--+1*2*3*n 下面是窗体,就一个按钮和编辑框. 中途还遇到了编码问题,但是感冒太难受,加上明天还要上课.就睡了~ 晚安世界.

  3. WordPress WooCommerce &OpenCurlyQuote;hide-wc-extensions-message’参数跨站脚本漏洞

    漏洞名称: WordPress WooCommerce ‘hide-wc-extensions-message’参数跨站脚本漏洞 CNNVD编号: CNNVD-201310-501 发布时间: 201 ...

  4. Excel——使用VLOOKUP函数关联跨工作薄数据

    实验环境 有两个工作簿,一个是<花名册>,另一个是<入离职表>,<花名册>上有所有员工的详细信息,包括员工的姓名.部门.出生日期等,<入离职表>上有离职 ...

  5. 认识input输入框的placeholder属性

    我们来认识下input输入框的placeholder属性. placeholder 属性提供可描述输入字段预期值的提示信息.(placeholder 属性适用于以下的 <input> 类型 ...

  6. iOS 生成随机颜色(UIColor)

    #import <UIKit/UIKit.h> @interface UIColor (RandomColor) +(UIColor *) randomColor; @end #impor ...

  7. windows&plus;nginx 查看并发链接数

    1.windows下nginx查看并发链接数要使用stable版本 2.配置代码: location /status { stub_status on; } 3.访问地址:http://localho ...

  8. idea安装了Mybaits Plugin插件后,启动不起来了

    之前安装了一些插件,谁知道重启完了之后,直接启动不起来了,报错信息如下: cannot load project fatal error initializing plugin com.seven7. ...

  9. 软工实践作业2:个人项目实战之Sudoku

    Github:Sudoku 项目相关要求 项目需求 利用程序随机构造出N个已解答的数独棋盘 . 输入 数独棋盘题目个数N(0<N<=1000000). 输出 随机生成N个不重复的已解答完毕 ...

  10. 在 laravel 的 DB&colon;&colon;transaction 中,为外部变量赋值

    例如,我想在 laravel 的事务中,对某个外部变量赋值,然后在后续的逻辑中判断该变量的属性 $user = null; // init DB::transaction(function() use ...

相关文章