题目链接:https://www.rqnoj.cn/problem/311

题意:

  给你一个长度为n的数字,用t个乘号分开,问你分开后乘积最大为多少。(6<=n<=40,1<=k<=30)

题解:

  简化问题:

    给原数字之前添加一个"1 *",乘号不计入数量,对答案无影响。

    例如:"1231"可以变成"(1*)1231"。

  表示状态:

    dp[i][j] = max num(最后一个乘号之前的最大乘积)

    i:此时在第i个数的前面添了一个乘号

    j:用了j个乘号

    例1:"(1*)12*31":

      dp[2][1] = 12 (数位从0开始从左向右编号)

    例2:"(1*)12*3*1"

      dp[3][2] = 12*3 = 36

  找出答案:

    max dp[i][t] * cal_sec(i,n-1)

    cal_sec(x,y)将数字串中[x,y]这个区间的字符串转化为数字

    例如:设n=4,t=1.

       此时为"(1*)12*31"

       则此时这种方案的乘积为dp[2][1]* "31" = 12*31

  如何转移:

    dp[i][j] = max dp[k][j-1] * cal_sec(k,i-1)

    在前面的某一段乘积后面再续上一串数字,达到第i位,用了j个乘号。

    前面的某一段乘积:枚举最后一个乘号在第k个数字之前,用了j-1个乘号。

    要续的数字:从第k位到i-1位 = cal_sec(k,i-1)

  边界条件:

    初始时用了0个乘号,但乘积为1。

    例如:"(1*)1231".

    特判:如果输入的数字就是0,则直接返回0.

  注:输入用string,答案用long long存。

    数据水。。。否则高精。。。

AC Code:

 // state expression:
// dp[i][j] = max num
// i: last '*' is in front of ith bit
// j: used j '*'
//
// find the answer:
// max dp[i][t] * cal_sec(i,len-1)
//
// transferring:
// dp[i][j] = max dp[k][j-1] * cal_sec(k,i-1)
//
// boundary:
// if input == 0: return 0
// else dp[0] = 1, others = -1
#include <iostream>
#include <stdio.h>
#include <string.h>
#define MAX_N 45
#define MAX_K 35 using namespace std; int n,t;
long long ans;
long long dp[MAX_N][MAX_K];
long long sec[MAX_N][MAX_N];
string s; void read()
{
cin>>n>>t>>s;
} long long cal_sec(int x,int y)
{
if(sec[x][y]!=-) return sec[x][y];
long long res=;
for(int i=x;i<=y;i++)
{
res=res*+s[i]-'';
}
return sec[x][y]=res;
} void solve()
{
memset(sec,-,sizeof(sec));
memset(dp,-,sizeof(dp));
dp[][]=;
for(int i=;i<n;i++)
{
for(int j=;j<=t && j<=i;j++)
{
for(int k=;k<i;k++)
{
if(dp[k][j-]!=-)
{
dp[i][j]=max(dp[i][j],dp[k][j-]*cal_sec(k,i-));
}
}
}
}
ans=;
for(int i=;i<n;i++)
{
if(dp[i][t]!=-) ans=max(ans,dp[i][t]*cal_sec(i,n-));
}
} void print()
{
cout<<ans<<endl;
} int main()
{
read();
solve();
print();
}

RQNOJ 311 [NOIP2000]乘积最大:划分型dp的更多相关文章

  1. codevs1040统计单词个数(区间+划分型dp)

    1040 统计单词个数 2001年NOIP全国联赛提高组  时间限制: 1 s  空间限制: 128000 KB  题目等级 : 黄金 Gold   题目描述 Description 给出一个长度不超 ...

  2. codevs3162抄书问题(划分型dp)

    3162 抄书问题  时间限制: 1 s  空间限制: 128000 KB  题目等级 : 钻石 Diamond   题目描述 Description 现在要把M本有顺序的书分给K个人复制(抄写),每 ...

  3. 125.乘积最大(划分性DP)

    1017 乘积最大 2000年NOIP全国联赛普及组NOIP全国联赛提高组  时间限制: 1 s  空间限制: 128000 KB  题目等级 : 黄金 Gold 题解 题目描述 Descriptio ...

  4. Codevs_1040_[NOIP2001]_统计单词个数_(划分型动态规划)

    描述 http://codevs.cn/problem/1040/ 与Codevs_1017_乘积最大很像,都是划分型dp. 给出一个字符串和几个单词,要求将字符串划分成k段,在每一段中求共有多少单词 ...

  5. Vijos_1218_数字游戏_(划分型动态规划+环状动态规划)

    描述 https://vijos.org/p/1218 给出n个数围成一个环,将其划分成k个部分,每个部分求和再对10取模,最后将每个部分的值相乘,求其最大值与最小值. 描述 丁丁最近沉迷于一个数字游 ...

  6. 洛谷 P1026 统计单词个数 (分组+子串预处理)(分组型dp再次总结)

    一看完这道题就知道是划分型dp 有两个点要注意 (1)怎么预处理子串. 表示以i为开头,结尾在j之前(含),有没有子串,有就1,没有就0 (2)dp的过程 这种分成k组最优的题目已经高度模板化了,我总 ...

  7. 划分型博弈型dp

    划分型动态规划: 513. Perfect Squares https://www.lintcode.com/problem/perfect-squares/description?_from=lad ...

  8. 区间型DP

    区间型DP是一类经典的动态规划问题,主要特征是可以先将大区间拆分成小区间求解最后由小区间的解得到大区间的解. 有三道例题 一.石子合并 在一个圆形操场的四周摆放N堆石子,现要将石子有次序地合并成一堆. ...

  9. POJ3659 Cell Phone Network(树上最小支配集:树型DP)

    题目求一棵树的最小支配数. 支配集,即把图的点分成两个集合,所有非支配集内的点都和支配集内的某一点相邻. 听说即使是二分图,最小支配集的求解也是还没多项式算法的.而树上求最小支配集树型DP就OK了. ...

随机推荐

  1. Solidworks如何使用Toolbox

    Toolbox不仅仅是智能扣件.事实上,一般常见的轴承,螺栓,齿轮都有了,点击右侧的设计库即可展开Toolbox   配置完成后我只留下一个GB   比如我要选一个圆锥滚子轴承,从右边拖进来即可   ...

  2. Solidworks如何开启自动求解

    1 我打开了一个DWG格式的文件,提示草图太大,关闭的自动求解(就是没法撤销了)   2 工具-草图设定-自动求解   3 随便做一个标注,然后发现撤销按钮可以使用了,点击之后也的确可以撤销刚才的操作 ...

  3. 微信小程序 - 非Form数据怎么发送到后端?

    通过设置异步缓存,就可以做到 wx.setStorageSync('imgs',imglist); 最后的提交信息:

  4. $ is not defined

    $ is not defined 引入Jquery的顺序不正确,要把它放在第一个引入

  5. sql数据分页

    方法一.直接限制返回区间 (只适应于mysql) SELECT * FROM table WHERE 查询条件 ORDER BY 排序条件 LIMIT ((页码-1)*页大小),页大小; 优点:写法简 ...

  6. python中给程序加锁之fcntl模块的使用

    python 中给文件加锁——fcntl模块import fcntl 打开一个文件##当前目录下test文件要先存在,如果不存在会报错.或者以写的方式打开f = open('./test')对该文件加 ...

  7. C#高级编程---暂停计划

    学了两个半月的C#高级编程这本书,看到了第三部分,说实话,我有点怂了,我认怂,临时先放一下,博客暂停,由于我的水平确实不会了,在写下去也是自欺欺人,我决定先研究研究我比較喜欢的脚本语言JS,開始写的, ...

  8. arcgis水文分析

    前言 1.在开始之前首先需要注意几点: 1.arcgis 需要 python2.7 的支持,并有必要的模块库,请一定注意避免与其他软件冲突,例如tecplot 2009 需要python2.5的支持, ...

  9. Java结束线程的三种方法

    线程属于一次性消耗品,在执行完run()方法之后线程便会正常结束了,线程结束后便会销毁,不能再次start,只能重新建立新的线程对象,但有时run()方法是永远不会结束的.例如在程序中使用线程进行So ...

  10. Map输出数据的处理类MapOutputBuffer分析

    MapOutputBuffer顾名思义就是Map输出结果的一个Buffer,用户在编写map方法的时候有一个参数OutputCollector: void map(K1 key, V1 value, ...