携程4月11日编程题 输出最大乘积 java
来源:互联网 发布:淘宝网建达巧克力 编辑:程序博客网 时间:2024/05/21 04:24
问题描述
有一个整数n,将n分解成若干个不同自然数之和,问如何分解能使这些数的乘积最大,输出这个乘积m
动态规划
根据题意,对于一个整数n,必然存在一个整数x,使得从n中分解出整数x可以使其最后获得最大乘积,这要求对n-x的分解也是最优解。我们用dp[i][j]表示从整数i分解出整数j的这种情况下,能达到的最大乘积。那么dp[i][j]可以递归的定义为
构造一个二维数组dp,自底向上计算结果,最后通过查表得到最终结果。
对于给定的整数n,最后的最大乘积为
实现代码
import java.util.Arrays;
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
while(sc.hasNext()){
int n = sc.nextInt();
//dp[i][j] 表示对i进行分解,从i中分解出整数j
int[][] dp = new int[n+1][n+1];
for(int i = 0; i <= n; i++)
dp[0][i] = 1;
for(int i = 1; i <= n; i++){
for(int j = 1; j <= i; j++){
for(int k = 0 ; k < j; k++)
dp[i][j] = Math.max(dp[i][j], dp[i - j][k] * j);
}
}
//找到最大值
int ans = 0;
for(int i = 0; i <= n; i++)
ans = Math.max(ans, dp[n][i]);
System.out.println(ans);
//遍历输出整个二维数组
for(int[] d:dp){
System.out.println(Arrays.toString(d));
}
}
}
}
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
while(sc.hasNext()){
int n = sc.nextInt();
//dp[i][j] 表示对i进行分解,从i中分解出整数j
int[][] dp = new int[n+1][n+1];
for(int i = 0; i <= n; i++)
dp[0][i] = 1;
for(int i = 1; i <= n; i++){
for(int j = 1; j <= i; j++){
for(int k = 0 ; k < j; k++)
dp[i][j] = Math.max(dp[i][j], dp[i - j][k] * j);
}
}
//找到最大值
int ans = 0;
for(int i = 0; i <= n; i++)
ans = Math.max(ans, dp[n][i]);
System.out.println(ans);
//遍历输出整个二维数组
for(int[] d:dp){
System.out.println(Arrays.toString(d));
}
}
}
}
阅读全文
1 0
- 携程4月11日编程题 输出最大乘积 java
- 2017年4月11日携程笔试题 乘积最大
- [编程题] 最大乘积
- 完美世界校招在线笔试题-互联网Java(11月1日)编程题
- 【算法题】最大乘积
- 【真题】拼多多2018校招内推编程题 最大乘积
- 今日头条 2017年秋招编程题 :“最大乘积和”
- 最大乘积子串-----输出子串和乘积
- java 11月6日
- 11月4日
- 11月4日
- Java程序练习-乘积最大
- 11月6日 哈工大c语言编程题
- java.io输出流--2011年08月31日
- 11月1日编程提示
- C++编程思想11月26日
- C++编程思想11月27日
- C++编程思想12月11日
- 旋转数组中的最小数字
- Bootstrap初识
- 关于python中值传递和引用传递的问题
- 习题 4.12 有4个圆塔,圆心分别为(2,2)、(-2,2)、(-2,-2)、(2,-2),圆半径为1,这4个塔的高度为10m,塔以外无建筑物。今输入任一点的坐标,求该点的建筑高度(塔外的高度为零)
- jQuery UI 工作原理
- 携程4月11日编程题 输出最大乘积 java
- 九、swift3.0可选类型+类型修饰符及其它
- Halcon算子函数[2]
- 基础算法题-链表相关
- java.util.Arrays
- 分布式系列文章——Paxos算法原理与推导
- 学习笔记—网页基础知识入门(二)
- 对于Struts2中通配符动态匹配method报错问题
- 链表实现任意精度整数运算