NYOJ746——整数划分(四)
描述
暑假来了,hrdv 又要留学校在参加ACM集训了,集训的生活非常Happy(ps:你懂得),可是他最近遇到了一个难题,让他百思不得其解,他非常郁闷。。亲爱的你能帮帮他吗?
问题是我们经常见到的整数划分,给出两个整数 n , m ,要求在 n 中加入m - 1 个乘号,将n分成m段,求出这m段的最大乘积
- 输入
- 第一行是一个整数T,表示有T组测试数据
接下来T行,每行有两个正整数 n,m ( 1<= n < 10^19, 0 < m <= n的位数); - 输出
- 输出每组测试样例结果为一个整数占一行
- 样例输入
-
2
111 2
1111 2 - 样例输出
-
11
121
-
这题是区间dp,用dp[i][j]表示前i个数中插入j个乘号所得的最大乘积,先初始化dp[i][1],然后用状态转移方程dp[i][j]=max(dp[i][j],dp[k][j-1]*shu(k+1,i));就可以了,注意要用unsigned long long
-
#include<iostream>
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<math.h>
#include<vector>
#include<map>
#include<set>
#include<queue>
#include<stack>
#include<string>
#include<algorithm>
using namespace std;
#define ll unsigned long long
char str[30];
ll dp[25][25];
ll shu(int l,int r)
{
int i,j;
ll num=0;
for(i=l;i<=r;i++){
num=num*10+str[i]-'0';
}
return num;
} int main()
{
int i,j,T,len1,len,m,k;
ll num;
scanf("%d",&T);
while(T--)
{
scanf("%s%d",str+1,&m);
len1=strlen(str+1);
m--;
if(len1==1){
printf("%lld\n",str[1]-'0');continue;
}
num=0;
if(m==0){
for(i=1;i<=len1;i++){
num=num*10+str[i]-'0';
}
printf("%llu\n",num);
continue;
}
memset(dp,0,sizeof(dp));
for(i=2;i<=len1;i++){
for(k=1;k<i;k++){
dp[i][1]=max(dp[i][1],shu(1,k)*shu(k+1,i));
}
}
for(j=2;j<=m;j++){
for(i=j+1;i<=len1;i++){
for(k=j;k<i;k++)
dp[i][j]=max(dp[i][j],dp[k][j-1]*shu(k+1,i));
} }
printf("%llu\n",dp[len1][m]);
}
return 0;
}
也可以用四边形优化:(和邮局那题差不多的优化思路)
-
#include<iostream>
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<math.h>
#include<vector>
#include<map>
#include<set>
#include<queue>
#include<stack>
#include<string>
#include<algorithm>
using namespace std;
#define ll unsigned long long
char str[30];
ll dp[25][25];
int s[25][25];
ll shu(int l,int r)
{
int i,j;
ll num=0;
for(i=l;i<=r;i++){
num=num*10+str[i]-'0';
}
return num;
} int main()
{
int i,j,T,len1,len,m,k;
ll num;
scanf("%d",&T);
while(T--)
{
scanf("%s%d",str+1,&m);
len1=strlen(str+1);
m--;
if(len1==1){
printf("%lld\n",str[1]-'0');continue;
}
num=0;
if(m==0){
for(i=1;i<=len1;i++){
num=num*10+str[i]-'0';
}
printf("%llu\n",num);
continue;
}
memset(dp,0,sizeof(dp));
for(i=2;i<=len1;i++){
for(k=1;k<i;k++){
dp[i][1]=max(dp[i][1],shu(1,k)*shu(k+1,i));
}
s[i][1]=2;
}
for(j=2;j<=m;j++){
s[len1+1][j]=len1-1;
for(i=len1;i>j;i--){
for(k=s[i][j-1];k<=s[i+1][j];k++){
if(dp[i][j]<dp[k][j-1]*shu(k+1,i)){
dp[i][j]=dp[k][j-1]*shu(k+1,i);
s[i][j]=k;
}
} /*for(k=j;k<i;k++){
dp[i][j]=max(dp[i][j],dp[k][j-1]*shu(k+1,i));
}*/
} }
printf("%llu\n",dp[len1][m]);
}
return 0;
}
NYOJ746——整数划分(四)的更多相关文章
- nyoj746 整数划分(四)
整数划分(四) 时间限制:1000 ms | 内存限制:65535 KB 难度:3 描述 暑假来了,hrdv 又要留学校在参加ACM集训了,集训的生活非常Happy(ps:你懂得),可是他最近遇到 ...
- nyoj746 整数划分
nyoj746 http://acm.nyist.net/JudgeOnline/problem.php?pid=746 一道区间dp的题目: 设:a[i][j]为那一串数字中从第i位到第j位的数是多 ...
- ACM 整数划分(四)
整数划分(四) 时间限制:1000 ms | 内存限制:65535 KB 难度:3 描述 暑假来了,hrdv 又要留学校在参加ACM集训了,集训的生活非常Happy(ps:你懂得),可是他最近 ...
- 整数划分 (区间DP)
整数划分(四) 时间限制:1000 ms | 内存限制:65535 KB 难度:3 描述 暑假来了,hrdv 又要留学校在参加ACM集训了,集训的生活非常Happy(ps:你懂得),可是他最近 ...
- 整数划分 Integer Partition(二)
本文是整数划分的第二节,主要介绍整数划分的一些性质. 一 先来弥补一下上一篇文章的遗留问题:要求我们所取的 (n=m1+m2+...+mi )中 m1 m2 ... mi连续,比如5=1+4就不符合 ...
- 大概是:整数划分||DP||母函数||递推
整数划分问题 整数划分是一个经典的问题. Input 每组输入是两个整数n和k.(1 <= n <= 50, 1 <= k <= n) Output 对于每组输入,请输出六行. ...
- HDU4632 Poj2955 括号匹配 整数划分 P1880 [NOI1995]石子合并 区间DP总结
题意:给定一个字符串 输出回文子序列的个数 一个字符也算一个回文 很明显的区间dp 就是要往区间小的压缩! #include<bits/stdc++.h> using namesp ...
- 【noi 2.6_8787】数的划分(DP){附【转】整数划分的解题方法}
题意:问把整数N分成K份的分法数.(与"放苹果"不同,在这题不可以有一份为空,但可以类比)解法:f[i][j]表示把i分成j份的方案数.f[i][j]=f[i-1][j-1](新开 ...
- 51nod p1201 整数划分
1201 整数划分 基准时间限制:1 秒 空间限制:131072 KB 分值: 80 难度:5级算法题 将N分为若干个不同整数的和,有多少种不同的划分方式,例如:n = 6,{6} {1,5} {2, ...
随机推荐
- 二进制格式 PLY 模型文件的读取与渲染
PLY 文件头部信息: ply format binary_little_endian 1.0 comment VCGLIB generated element vertex 13469 proper ...
- 用js实现打印九九乘法表
用js在打印九九乘法表 思考 在学习了流程控制和条件判断后,我们可以利用js打印各式各样的九九乘法表 不管是打印什么样三角形九九乘法表,我们都应该找到有规律的地方,比如第一列的数字是什么规律,第一行的 ...
- 【Spring】Spring中的Bean - 1、Baen配置
Bean配置 简单记录-Java EE企业级应用开发教程(Spring+Spring MVC+MyBatis)-Spring中的Bean 什么是Spring中的Bean? Spring可以被看作是一个 ...
- 【Software Test】Basic Of ST
文章目录 Learning Objective Introduction Software Applications Before Software Testing What is testing? ...
- Electron小白入门自学笔记(一)
码文不易啊,转载请带上本文链接呀,感谢感谢 https://www.cnblogs.com/echoyya/p/14297176.html 一.从Hello Electron开始 创建一个空的文件夹, ...
- js千分位分隔,数字货币化方法学习记录
js千分位分隔,数字货币化-4种方法(含正则) 方法1-整数货币化 // 整数货币化 function intCurrency(num) { var reg = new RegExp("^[ ...
- 太极图HTML+CSS(可旋转)代码记录
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...
- Jmeter-插件扩展及性能监控插件的安装
需要对http服务进行大数据量的传值测试:看看产品中的http服务,能支持传多少字符:目标值是希望能到10w+: 上次测试中,服务器总是内存满导致服务不响应,因此想增加对服务端的性能监控:查阅了smi ...
- idea maven package报错"不再支持源选项 5 请使用 6 或更高版本。不支持发行版本 5"
解决办法: 1.确保java compile以及project和module的java字节码版本是所用的java版本:
- IDEA SSM后端框架入门
SSM框架 如果对SSM一无所知,推荐先去看这本书,可以在微信读书上看. 知识点 控制器返回对象时,对象需要有getter,setter方法,才能自动转化为json数据类型. 一个服务管理者对应多个业 ...