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

贵阳网站建设加q479185700wordpress 静态发布

贵阳网站建设加q479185700,wordpress 静态发布,网站规划与网页设计案例,机构网站建设343. 整数拆分 给定一个正整数 n #xff0c;将其拆分为 k 个 正整数 的和#xff08; k 2 #xff09;#xff0c;并使这些整数的乘积最大化。 返回 你可以获得的最大乘积 。 示例 1: 输入: n 2 输出: 1 解释: 2 1 1, 1 1 1。示例 2: 输入: n 10 输出: 36…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 思路(动态规划) 法一 对于正整数 n当 n ≥ 2 时可以拆分成至少两个正整数的和。令 x 是拆分出的第一个正整数则剩下的部分是 n − xn − x 可以不继续拆分或者继续拆分成至少两个正整数的和。由于每个正整数对应的最大乘积取决于比它小的正整数对应的最大乘积因此可以使用动态规划求解。 创建数组 dp其中 dp[i] 表示将正整数 i 拆分成至少两个正整数的和之后这些正整数的最大乘积。特别地0 不是正整数1 是最小的正整数0 和 1 都不能拆分因此 dp[0] dp[1] 0。 当 i ≥ 2 时假设对正整数 i 拆分出的第一个正整数是 j1 ≤ j i则有以下两种方案 将 i 拆分成 j 和 i − j 的和且 i − j 不再拆分成多个正整数此时的乘积是 j × (i − j)将 i 拆分成 j 和 i − j 的和且 i − j 继续拆分成多个正整数此时的乘积是 j × dp[i − j]。 因此当 j 固定时有 dp[i] max⁡(j × (i − j), j × dp[i − j])。由于 j 的取值范围是 1 到 i − 1需要遍历所有的 jjj 得到 dp[i] 的最大值因此可以得到状态转移方程如下 dp[i]max⁡1≤ji{max⁡(j×(i−j),j×dp[i−j])}d p[i]\max _{1 \leq ji}\{\max (j \times(i-j), j \times d p[i-j])\} dp[i]1≤jimax​{max(j×(i−j),j×dp[i−j])} 最终得到 dp[n] 的值即为将正整数 n 拆分成至少两个正整数的和之后这些正整数的最大乘积。 法二 由于分解成正整数的乘积最大若分解的正整数有1不会使乘积变大所以分解的正整数大于等于2 又至少分解2个正整数当 n 2,或 n 3 时最大的乘积分别为1和2n 4 时分解的最小整数为2否则只会变小 举一些栗子 4 2 2 2 * 2 4 5 2 3 2 * 3 6 6 3 3 3 * 3 9 7 2 2 3 2 5 8 2 3 3 2 6 9 4 2 3 2 7 10 3 3 4 3 7创建数组 dp其中 dp[i] 表示将正整数 i 拆分成至少两个正整数的和之后这些正整数的最大乘积。由以上可知分解的都可表示为 2 或 3 与另一个数 j最大乘积就是2 或 3 乘以另一个数的最大乘积dp[j]. 代码:(Java) 法一 public class IntegerBreak {public static void main(String[] args) {// TODO Auto-generated method stubint n 10;System.out.println(integerBreak(n));}int[] dp new int[n 1];dp[1] 1;for (int i 2; i n; i) {for (int j 1; j i - 1; j) {dp[i] Math.max(dp[i], Math.max(j * dp[i - j], j * (i - j)));}}return dp[n]; }法二 public class IntegerBreak {public static void main(String[] args) {// TODO Auto-generated method stubint n 10;System.out.println(integerBreak(n));}public static int integerBreak(int n) {if(n / 2 2) {return n - 1;}int[] dp new int[n 1];dp[2] 2;dp[3] 3;for(int i 4; i n; i) {dp[i] Math.max(2*dp[i-2], 3*dp[i-3]);}return dp[n];} }运行结果 复杂度分析 时间复杂度O(n2)O(n^2)O(n2)其中 n 是给定的正整数。对于从 2 到 n 的每一个整数都要计算对应的 dp 值计算一个整数对应的 dp 值需要 O(n) 的时间复杂度因此总时间复杂度是 O(n2)。(法二时间复杂度为O(n)) 空间复杂度O(n)其中 n 是给定的正整数。创建一个数组 dp其长度为 n1 注仅供学习参考 题目来源力扣。
http://www.w-s-a.com/news/998370/

相关文章:

  • 陕西建设厅人才网站ai生成logo免费
  • 建设家居网站村建站什么部门
  • 网站建设+青海龙岗区网站建设
  • 精品课网站建设网络公司名字怎么取
  • 化工网站制作用户体验设计案例
  • 如何在微信公众平台上建立微网站垂直门户网站怎么做
  • 关于销售网站有哪些内容品牌网站建设小科6a蚪
  • 免费制作网站平台哪个好湖南企业建网站
  • 灞桥微网站建设株洲百姓网
  • 儿童网站建设互联网怎么学
  • 重庆建网站的公司集中在哪里中煤第五建设有限公司网站
  • 成都网站建设987net运维需要掌握哪些知识
  • 网站建设师个人简介怎么写WordPress头像美化插件
  • 网站优化知识销售管理系统c语言
  • 桂林市网站设计厦门自己建网站
  • 网站seo哪里做的好东莞做网站优化的公司
  • 休闲采摘园网站建设政务公开和网站建设工作的建议
  • 长沙网站建设哪个公司好PHP amp MySQL网站建设宝典
  • 代码编辑器做热点什么网站好湛江网站建设哪家好
  • php网站开发概念网站开发岗位职责任职责格
  • asp 网站源码 下载西安自适应网站建设
  • 白领兼职做网站贵阳网站设计哪家好
  • 热水器网站建设 中企动力企业网站开发需要多钱
  • 北京市建设工程信息网交易网站静态网页模板免费下载网站
  • 福田欧曼服务站网站前台设计
  • 网站做系统叫什么软件吗注册域名需要实名认证吗
  • jsp网站开发教学视频ui设计风格
  • 注册网站建设开发怎么自己做导航网站
  • 设计做网站品牌咖啡主题网页界面设计
  • 个人网站制作总体设计宿迁房价2023年最新房价