dp1--乘积最大
dp1--乘积最大
一、心得
1、用excel填数组很方便
2、
dp就是填表
找状态就是缩小规模
找状态转移方程就是 找状态的最后一次关系
二、题目
8782:乘积最大
- 总时间限制:
- 1000ms
- 内存限制:
- 65536kB
- 描述
-
今年是国际数学联盟确定的“2000——世界数学年”,又恰逢我国著名数学家华罗庚先生诞辰90周年。在华罗庚先生的家乡江苏金坛,组织了一场别开生面的数学智力竞赛的活动,你的一个好朋友XZ也有幸得以参加。活动中,主持人给所有参加活动的选手出了这样一道题目:
设有一个长度为N的数字串,要求选手使用K个乘号将它分成K+1个部分,找出一种分法,使得这K+1个部分的乘积能够为最大。
同时,为了帮助选手能够正确理解题意,主持人还举了如下的一个例子:
有一个数字串:312,当N=3,K=1时会有以下两种分法:
1) 3*12=36
2) 31*2=62
这时,符合题目要求的结果是:31*2=62
现在,请你帮助你的好朋友XZ设计一个程序,求得正确的答案。
- 输入
- 程序的输入共有两行:
第一行共有2个自然数N,K(6≤N≤40,1≤K≤6)
第二行是一个长度为N的数字串。 - 输出
- 输出所求得的最大乘积(一个自然数)。(保证最终答案不超过int范围)
- 样例输入
-
4 2
1231 - 样例输出
-
62
- 来源
- NOIP2000复赛 普及组 第三题
三、分析
* 乘积最大
* 状态:
* f[i][j]表示前j个数字中插入j个乘号
* a[i][j]表示数字串i位置到j位置组成的数的值
* 初始状态:f[1][0]=a[1][1]
* 最终状态:f[n][k]
* 状态转移方程:
* 默认乘号插在数字之后
* 最后一个乘号插的位置m的取值范围为(k,n-1)
* f[i][j]=max(f[m][j-1]*a[m+1][i]) (m>=j&&m<=i-1)
1、求a数组

2、求dp

四、AC代码
/*
* 乘积最大
* 状态:
* f[i][j]表示前j个数字中插入j个乘号
* a[i][j]表示数字串i位置到j位置组成的数的值
* 初始状态:f[1][0]=a[1][1]
* 最终状态:f[n][k]
* 状态转移方程:
* 默认乘号插在数字之后
* 最后一个乘号插的位置m的取值范围为(k,n-1)
* f[i][j]=max(f[m][j-1]*a[m+1][i]) (m>=j&&m<=i-1)
*/ #include <iostream>
#include <string>
using namespace std;
int f[][];
int a[][];
int n, k;
string s; //数字串 void initArr_a() {
for (int i = ; i <= n; i++) {
a[i][i] = s[i - ] - '';
}
//根据excel表格自己写,其实很简单
for (int i = ; i <= n; i++) {
for (int j = i + ; j <= n; j++) {
a[i][j] = a[i][j - ] * + a[j][j];
}
}
} void printArr_a() {
for (int i = ; i <= n; i++) {
for (int j = ; j <= n; j++) {
cout << a[i][j] << " ";
}
cout << endl;
}
} void initArr_f() {
//竖直 f[i][0]
for (int i = ; i <= n; i++) {
f[i][] = a[][i];
}
//水平 f[0][j]
for (int j = ; j <= k; j++) {
f[][j] = ;
}
//其它部位
for (int i = ; i <= n; i++) {
for (int j = ; j <= k; j++) {
f[i][j] = ;
}
}
} void printArr_f() {
for (int i = ; i <= n; i++) {
for (int j = ; j <= k; j++) {
cout << f[i][j] << " ";
}
cout << endl;
}
} void init() {
cin >> n >> k;
cin >> s;
initArr_a();
//printArr_a();
initArr_f();
//printArr_f();
} void dp() {
for (int i = ; i <= n; i++) {
for (int j = ; j <= k; j++) {
for (int m = j; m <= i - ; m++) {
f[i][j] = max(f[i][j], f[m][j - ] * a[m + ][i]);
}
}
}
//printArr_f();
} void printAns(){
cout<<f[n][k]<<endl;
} int main() {
//freopen("src/in8782.txt", "r", stdin);
init();
dp();
printAns();
return ;
}
五、注意点
dp1--乘积最大的更多相关文章
- 动态规划:最大连续子序列乘积 分类: c/c++ 算法 2014-09-30 17:03 656人阅读 评论(0) 收藏
题目描述: 给定一个浮点数序列(可能有正数.0和负数),求出一个最大的连续子序列乘积. 分析:若暴力求解,需要O(n^3)时间,太低效,故使用动态规划. 设data[i]:第i个数据,dp[i]:以第 ...
- [LeetCode] Maximum Product Subarray 求最大子数组乘积
Find the contiguous subarray within an array (containing at least one number) which has the largest ...
- C语言 · 最小乘积(基本型)
问题描述 给两组数,各n个. 请调整每组数的排列顺序,使得两组数据相同下标元素对应相乘,然后相加的和最小.要求程序输出这个最小值. 例如两组数分别为:1 3 -5和-2 4 1 那么对应乘积取和的最小 ...
- 最大连续子序列乘积(DP)
题目来源:小米手机2013年校园招聘笔试题 题目描述: 给定一个浮点数序列(可能有正数.0和负数),求出一个最大的连续子序列乘积. 输入: 输入可能包含多个测试样例.每个测试样例的第一行仅包含正整数 ...
- 给定一个double类型的数组arr,其中的元素可正可负可0,返回子数组累乘的最大乘积。例如arr=[-2.5,4,0,3,0.5,8,-1],子数组[3,0.5,8]累乘可以获得最大的乘积12,所以返回12。
分析,是一个dp的题目, 设f[i]表示以i为结尾的最大值,g[i]表示以i结尾的最小值,那么 f[i+1] = max{f[i]*arr[i+1], g[i]*arr[i+1],arr[i+1]} ...
- CentOS 7 ssh脚本 求两个数值的“和”,“乘积”,”商“
1:在目录下创建一个 sh文件 touch 1.sh 2:进入sh文件书写sh脚本 #!/bin/bash read -p "请输入第一个数值" A read -p " ...
- NOIP2000乘积最大[序列DP]
题目描述 今年是国际数学联盟确定的“2000――世界数学年”,又恰逢我国著名数学家华罗庚先生诞辰90周年.在华罗庚先生的家乡江苏金坛,组织了一场别开生面的数学智力竞赛的活动,你的一个好朋友XZ也有幸得 ...
- n数乘积第m小
这是从Java贴吧看到的一道面试题,看了别人的解题思路实现的.... 如题: n个数,他们的乘积可得到一些其它的数,求第m小的. 输入格式: n m n1 n2 n3 ... 例: 输入: 3 8 2 ...
- 【wikioi】1017 乘积最大
题目链接 算法:划分型DP 非常典型的一道题目,划分型DP 题目描述: 设有一个长度为N的数字串,要求选手使用K个乘号将它分成K+1个部分,找出一种分法,使得这K+1个部分的乘积能够为最大.同时,为了 ...
- 最大乘积 Maximun Product
最大乘积 题目链接:http://acm.hust.edu.cn/vjudge/contest/view.action?cid=84562#problem/B 题意: 输入n个元素组成的序列s,你需要 ...
随机推荐
- mongodb基础操作
查询选择器>db.customers.find({age:{$lt:102}})查询age小于102的数据$lte表示小于或等于$gt表示大于$gte表示大于或等于>db.customer ...
- jQuery获取相邻标签的值
<!-- Mazey's jQuery --><script language="javascript" type="text/javascript&q ...
- Unix/Linux中Cron的用法
cron是unix或者linux下用来定时任务的命令,大致的用法如下: 1.服务的启动和关闭 /sbin/service crond start //启动服务 /sbin/service cr ...
- MySQL中自适应哈希索引
自适应哈希索引采用之前讨论的哈希表的方式实现,不同的是,这仅是数据库自身创建并使用的,DBA本身并不能对其进行干预.自适应哈希索引近哈希函数映射到一个哈希表中,因此对于字典类型的查找非常快速,如SEL ...
- Linux中权限管理之文件特殊权限
SetUID 1.只有在可执行的二进制程序上设定SUID权限才是有意义的 2.命令执行者要对该程序拥有执行权限 3.命令执行者在执行该程序时获得该程序文件属主的身份 4.SetUID权限只在该程序执行 ...
- python requests 使用
快速上手 迫不及待了吗?本页内容为如何入门 Requests 提供了很好的指引.其假设你已经安装了 Requests.如果还没有,去安装一节看看吧. 首先,确认一下: Requests 已安装 Req ...
- (2.3)学习笔记之mysql基础操作(表/库操作)
本系列学习笔记主要讲如下几个方面: 本文笔记[六:表操作--线上可以直接删除表吗?] 附加:库操作 [1]创建制定字符集的数据库 需求描述: 在创建DB的时候指定字符集. 操作过程: 1.使用crea ...
- 017-Hadoop Hive sql语法详解7-去重排序、数据倾斜
一.数据去重排序 1.1.去重 distinct与group by 尽量避免使用distinct进行排重,特别是大表操作,用group by代替 -- 不建议 select DISTINCT key ...
- 安装MySQL的详细步骤
安装步骤如下: 1.打开网址:http://www.mysql.com/ ↓ 2.选择“Download”->“Windows”(此安装步骤只是在Window10 中进行,如有需要,其他系统可参 ...
- 《Effective MySQL之SQL语句最优化》读书笔记——乱七八糟系列(给自己看)
该书区别于诸如<MySQL技术内幕——InnoDB存储引擎>等书的一大特色是该书主要讲的是MySQL数据库中的索引技术,并分别讲了InnoDB.MyISAM.Memory三个存储引擎.其中 ...