当前位置: 首页 > article >正文

力扣--343.整数拆分

题目

给定一个正整数 n ,将其拆分为 k 个 正整数 的和( k >= 2 ),并使这些整数的乘积最大化。

返回 你可以获得的最大乘积 。

示例 1:

输入: n = 2
输出: 1
解释: 2 = 1 + 1, 1 × 1 = 1。

示例 2:

输入: n = 10
输出: 36
解释: 10 = 3 + 3 + 4, 3 × 3 × 4 = 36。

提示:

2 <= n <= 58

代码

class Solution {
public int integerBreak(int n) {
//dp[i] 为正整数 i 拆分后的结果的最大乘积
int[] dp = new int[n+1];
dp[2] = 1;
for(int i = 3; i <= n; i++) {
for(int j = 1; j <= i-j; j++) {
// 这里的 j 其实最大值为 i-j,再大只不过是重复而已,
//并且,在本题中,我们分析 dp[0], dp[1]都是无意义的,
//j 最大到 i-j,就不会用到 dp[0]与dp[1]
dp[i] = Math.max(dp[i], Math.max(j*(i-j), jdp[i-j]));
// j * (i - j) 是单纯的把整数 i 拆分为两个数 也就是 i,i-j ,再相乘
//而j * dp[i - j]是将 i 拆分成两个以及两个以上的个数,再相乘。
}
}
return dp[n];
}
}
dp[i] = Math.max(dp[i], Math.max(j
(i-j), j*dp[i-j]));
现有的 dp[i] 值和新计算出的最大乘积之间选择较大的一个来更新 dp[i]。这是因为我们希望找到所有可能拆分方式中能得到的最大乘积。

贪心算法
class Solution {
public int integerBreak(int n) {
// with 贪心
// 通过数学原理拆出更多的3乘积越大,则
/**
@Param: an int, the integer we need to break.
@Return: an int, the maximum integer after breaking
@Method: Using math principle to solve this problem
@Time complexity: O(1)
**/
if(n == 2) return 1;
if(n == 3) return 2;
int result = 1;
while(n > 4) {
n-=3;
result =3;
}
return result
n;
}
}


http://www.kler.cn/a/467894.html

相关文章:

  • 遗传学的“正反”之道:探寻生命密码的两把钥匙
  • 使用 `llama_index` 构建智能问答系统:多种文档切片方法的评估
  • 【数据可视化-11】全国大学数据可视化分析
  • linux定时执行脚本的方法
  • MySQL(六)MySQL 案例
  • 音视频入门基础:MPEG2-PS专题(5)——FFmpeg源码中,解析PS流中的PES流的实现
  • RAG(Retrieval-Augmented Generation,检索增强生成)流程
  • 【leetcode100】二叉树的直径
  • 正则表达式在JSON里报错
  • .NET框架用C#实现PDF转HTML
  • 下载linux aarch64版本的htop
  • 对一段已知行情用python中画出K线图~
  • 利用LlamaIndex实现超参数调优自动化
  • 【数据结构】链表链表
  • 若依修改超级管理员admin的密码
  • 【Leetcode 每日一题】732. 我的日程安排表 III
  • 【阅读笔记】基于FPGA的红外图像二阶牛顿插值算法的实现
  • CSS——1.优缺点
  • 权限管理的方法
  • 微信小程序页面传参传对象
  • 特种作业操作证考试题库及答案(登高架设作业)
  • 功能篇:vue中的vuex使用例子
  • windows11(或centos7)安装nvidia显卡驱动、CUDA、cuDNN
  • Lucas-Kanade光流法详解
  • vue路由模式面试题
  • ffmpeg filter 滤镜命令