ssl1007 and ssl -最大乘积 and 加法最大【区间dp练习】

Description
  今年是国际数学联盟确定的“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设计一个程序,求得正确的答案。

Input
  程序的输入共有两行:
  第一行共有2个自然数N,K(6≤N≤40,1≤K≤6)
  第二行是一个长度为N的数字串。

Output

  相对于输入,应输出所求得的最大乘积(一个自然数)。


Sample Input
  4 2
  1231

Sample Output

  62


解题思路

 很明显,这是一个区间型动规,用f[i][j]表示前i个已经插入了j个乘号的最大乘积。

   然后为了方便,我们可以用数组是s[i][j]表示从第i到j的数。

   然后就推出动态转移方程f[i][k]=max(f[i][k],f[j][k-1]*s[j+1][i]);

   这里表示插入第的k个符号,前i个数,在j处插入乘号。


代码

#include<cstdio>
#include<iostream>
using namespace std;
int n,k;
long long s[11][11],f[11][11];
char c;
int main()
{
  scanf("%d%d\n",&n,&k);
  for (int i=1;i<=n;i++)
  {
    c=getchar();
    s[i][i]=c-48;//输入
  }
  for (int i=1;i<n;i++)
    for (int j=i+1;j<=n;j++)
    {
      s[i][j]=s[i][j-1]*10+s[j][j];//自己看思路↑
    }
  for (int i=1;i<=n;i++)
    f[i][0]=s[1][i];//不插符号时的预处理
  for (int ki=1;ki<=k;ki++)//插入第k个符号
    for (int i=ki+1;i<=n;i++)//枚举前i个
      for (int j=ki;j<i;j++)//枚举插入的位置
        f[i][ki]=max(f[i][ki],f[j][ki-1]*s[j+1][i]);

//动态转移方程
  printf("%lld",f[n][k]);//输出
}



第二题:加法最大

Description 
  设有一个长度为n的数字字符串,分成k+1个部份,使其k+1部份相加的和为最大。例如:数字串'340670',k=1,其加法有
  3+40670=40673 34+0670=704 340+670=1010 3406+70=3476 34076+0=34076
其最大和为40676。
问题:当数字串和k给出后,找出一个分法使和为最大。


Sample Input  

  6 1

    340670


Sample Output 

  40673


解题思路

  很明显,这是一个区间型动规,用f[i][j]表示前i个已经插入了j个乘号的最大和。

   然后为了方便,我们可以用数组是s[i][j]表示从第i到j的数。

   然后就推出动态转移方程f[i][k]=max(f[i][k],f[j][k-1]+s[j+1][i]);

   这里表示插入第的k个符号,前i个数,在j处插入加号。


代码

#include<cstdio>
#include<iostream>
using namespace std;
int n,k;
long long s[11][11],f[11][11];
char c;
int main()
{
  scanf("%d%d\n",&n,&k);
  for (int i=1;i<=n;i++)
  {
    c=getchar();
    s[i][i]=c-48;//输入
  }
  for (int i=1;i<n;i++)
    for (int j=i+1;j<=n;j++)
    {
      s[i][j]=s[i][j-1]*10+s[j][j];//自己看思路↑
    }
  for (int i=1;i<=n;i++)
    f[i][0]=s[1][i];//不插符号时的预处理
  for (int ki=1;ki<=k;ki++)//插入第k个符号
    for (int i=ki+1;i<=n;i++)//枚举前i个
      for (int j=ki;j<i;j++)//枚举插入的位置
        f[i][ki]=max(f[i][ki],f[j][ki-1]+s[j+1][i]);

//动态转移方程
  printf("%lld",f[n][k]);//输出
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/325139.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

一个java源文件中可以声明多少个class与编译后会生成多少个字节码文件

在一个java源文件中可以声明多个class。 但是&#xff0c;只能最多有一个类声明为public的。 而且要求声明为public的类的类名必须与源文件名相同。 编译的过程 编译以后&#xff0c;会生成一个或多个字节码文件。字节码文件的文件名与java源文件中的类名相同。 运行 只能运…

用户管理

用户管理 查询用户 use mysql select * from user use mydb select * from mysql.user – 创建用户 create user ‘zhangsan’ identified by ‘zhangsan’ – create user ‘用户名’‘主机名’ identified by ‘密码’ create user ‘lisi’‘localhost’ identified by ‘…

JavaFX UI控件教程(二)之JavaFX UI控件

翻译自 JavaFX UI控件 本章概述了通过API提供的JavaFX UI控件。 JavaFX UI控件是使用场景图中的节点构建的。因此&#xff0c;控件可以使用JavaFX平台的视觉丰富功能。由于JavaFX API完全用Java实现&#xff0c;因此您可以轻松地将JavaFX UI控件集成到现有的Java应用程序中…

《走遍中国》珍藏版(六)

Console.WriteLine("上一本书已经看完&#xff0c;从今天开始看下一本"); System.out.println("《走遍中国》珍藏版"); System.out.println("这本书是关于地理的"); System.out.println("地理往往是和历史进行紧密联系的");草长莺飞&a…

JDK,JRE,JVM三者的关系

JDKJREJava的开发工具(javac.exe,java.exe,javadoc.exe) JREJVMJava核心类库

ssl1597-石子合并问题【区间dp练习】

Description   在一个圆形操场的四周摆放着n 堆石子。现要将石子有次序地合并成一堆。规定每次只能选相邻的2 堆石子合并成新的一堆&#xff0c;并将新的一堆石子数记为该次合并的得分。试设计一个算法&#xff0c;计算出将n堆石子合并成一堆的最小得分和最大得分。 编程任务…

JavaFX UI控件教程(三)之Label

翻译自 Label 本章介绍如何使用Label驻留在javafx.scene.controlJavaFX API包中的类来显示文本元素。了解如何包装文本元素以适合特定空间&#xff0c;添加图形图像或应用视觉效果。 图2-1显示了三种常见的标签用法。左侧的标签是带有图像的文本元素&#xff0c;中间的标签表…

asp.net core中负载均衡场景下http重定向https的问题

上周欣喜地发现&#xff0c;微软官方终于针对 asp.net core 在使用负载均衡的情况下从 http 强制重定向至 https 的问题提供了解决方法。 app.UseForwardedHeaders(new ForwardedHeadersOptions {ForwardedHeaders ForwardedHeaders.XForwardedProto });var options new Rew…

《走遍中国》珍藏版(七)

Console.WriteLine("上一本书已经看完&#xff0c;从今天开始看下一本"); System.out.println("《走遍中国》珍藏版"); System.out.println("这本书是关于地理的"); System.out.println("地理往往是和历史进行紧密联系的");鸣沙山群峰…

JavaFX UI控件教程(四)之Button

翻译自 Button Button通过JavaFX API提供的类使开发人员能够在用户单击按钮时处理操作。该Button班是的扩展Labeled类。它可以显示文本&#xff0c;图像或两者。图3-1显示了具有各种效果的按钮。在本章中&#xff0c;您将学习如何创建这些按钮类型。 图3-1按钮类型 创建一个按…

角色管理

角色管理 MySQL8新增的功能 – 创建角色 role create role ‘dev_read’,‘dev_write’ – 给角色分配权限 grant select on mydb.* to ‘dev_read’ grant insert,update,delete on mydb.* to ‘dev_write’ – 创建用户 create user ‘user1’‘localhost’ identified b…

ssl1056-金明的预算方案【dp之有依赖的背包】

这道题卡了挺久的QAQ现在才搞定 Description   金明今天很开心&#xff0c;家里购置的新房就要领钥匙了&#xff0c;新房里有一间金明自己专用的很宽敞的房间。更让他高兴的是&#xff0c;妈妈昨天对他说&#xff1a;“你的房间需要购买哪些物品&#xff0c;怎么布置&#x…

《走遍中国》珍藏版(八)

Console.WriteLine("上一本书已经看完&#xff0c;从今天开始看下一本"); System.out.println("《走遍中国》珍藏版"); System.out.println("这本书是关于地理的"); System.out.println("地理往往是和历史进行紧密联系的");天地之间&a…

.Net Core应用搭建的分布式邮件系统设计

本篇分享的是由NetCore搭建的分布式邮件系统&#xff0c;主要采用NetCore的Api和控制台应用程序&#xff0c;由于此系统属于公司的所以这里只能分享设计图和一些单纯不设计业务的类或方法&#xff1b; 为什么要在公司中首例采用NetCore做开发 为什么要在公司中首例采用NetCore…

Java标识符与命名规则

标识符 标识符 Java 对各种变量、方法和类等要素命名时使用的字符序列称为标识符 技巧&#xff1a;凡是自己可以起名字的地方都叫标识符。 定义合法标识符规则 由26个英文字母大小写&#xff0c;0-9 &#xff0c;_或$组成 数字不可以开头。 不可以使用关键字和保留字&am…

JavaFX UI控件教程(五)之Radio Button

翻译自 Radio Button 本章讨论单选按钮控件和RadioButton类&#xff0c;该类的一个专门实现ToggleButton。 可以选择或取消选择单选按钮控件。通常&#xff0c;单选按钮组合成一个组&#xff0c;其中一次只能选择一个按钮。此行为将它们与切换按钮区分开来&#xff0c;因为组…

查询练习

简单查询 ①求js9901班的学生学号和姓名。 select s_no,s_name from student where class_no ‘js9901’ ②求计算机系的所有班级号和班级名。 select class_no,class_name from class where class_dept ‘计算机系’ ③求选修了课程的学生学号。 select s_no from choice ④…

《走遍中国》珍藏版(九)

Console.WriteLine("上一本书已经看完&#xff0c;从今天开始看下一本"); System.out.println("《走遍中国》珍藏版"); System.out.println("这本书是关于地理的"); System.out.println("地理往往是和历史进行紧密联系的");那一天&…

ssl1236-逃亡准备【dp之多重背包】

Description在《Harry Potter and the Deathly Hallows》中&#xff0c;Harry Potter他们一起逃亡&#xff0c;现在有许多的东西要放到赫敏的包里面&#xff0c;但是包的大小有限&#xff0c;所以我们只能够在里面放入非常重要的物品&#xff0c;现在给出该种物品的数量、体积、…