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

家教网站怎么做前端做微网站

家教网站怎么做,前端做微网站,遵义湘江投资建设有限责任公司门户网站,顺德家居企业网站建设目录 一.题目 二.解题思路 三.解题代码 一.题目 918. 环形子数组的最大和 给定一个长度为 n 的环形整数数组 nums ,返回 nums 的非空 子数组 的最大可能和 。 环形数组 意味着数组的末端将会与开头相连呈环状。形式上, nums[i] 的下一个元素是 nums[…

目录

一.题目

二.解题思路

三.解题代码

 


一.题目

918. 环形子数组的最大和

给定一个长度为 n 的环形整数数组 nums ,返回 nums 的非空 子数组 的最大可能和 

环形数组 意味着数组的末端将会与开头相连呈环状。形式上, nums[i] 的下一个元素是 nums[(i + 1) % n] , nums[i] 的前一个元素是 nums[(i - 1 + n) % n] 。

子数组 最多只能包含固定缓冲区 nums 中的每个元素一次。形式上,对于子数组 nums[i], nums[i + 1], ..., nums[j] ,不存在 i <= k1, k2 <= j 其中 k1 % n == k2 % n 。

示例 1:

输入:nums = [1,-2,3,-2]
输出:3
解释:从子数组 [3] 得到最大和 3

示例 2:

输入:nums = [5,-3,5]
输出:10
解释:从子数组 [5,5] 得到最大和 5 + 5 = 10

示例 3:

输入:nums = [3,-2,2,-3]
输出:3
解释:从子数组 [3] 和 [3,-2,2] 都可以得到最大和 3

提示:

  • n == nums.length
  • 1 <= n <= 3 * 104
  • -3 * 104 <= nums[i] <= 3 * 104

二.解题思路

动态规划解法:

   

    g[i] 表示以i位置为结尾的所有子数组的最小和

    环形数组的子数组的最大和有两种情况:

    1.拥有最大和的子数组就在数组的中间

    2.环形数组的头部和尾部共同组成了拥有最大和的子数组

    我们只需要求两种情况的最大值,再确定哪种更大返回即可

    对于1:

     f[i] 表示以i位置为结尾的所有子数组的最大和

     当长度为1时,子数组的最大和为nums[i]

     当长度大于1时,子数组的最大和nums[i]+f[i-1]

    状态转移方程: f[i]=Math.max(nums[i],f[i-1]);

    对于2:

    转化为求数组中间的最小子数组和,用数组总和sum-数组中间的最小子数组和(gmin)

    同理:

    最小和的状态转移方程: g[i]=Math.min(nums[i],g[i-1]);

    初始化:可以添加一个虚拟的头部,在状态数组里多开一个空间,填入0

     可以使填了0可以使原来的结果不变,f[0]=g[0]=0,

     循环填状态方程时就可以直接从1开始,状态数组多加了一个格子,注意下标映射

     原数组nums[i]变成nums[i-1]

     返回值:注意如果数组全部为负数如 [-1,-2,-3],

     那么最大的子数组应该在数组中间,直接返回fmax

三.解题代码

public int maxSubarraySumCircular(int[] nums) {int n=nums.length;int[] f=new int[n+1];int[] g=new int[n+1];int fmax=Integer.MIN_VALUE;int gmin=Integer.MAX_VALUE;int sum=0;for(int i=1;i<=n;i++){sum+=nums[i-1]; //求总数组和f[i] = Math.max(nums[i-1],nums[i-1] + f[i-1]);fmax = Math.max(fmax,f[i]);//求数组中间的最大子数组和g[i] = Math.min(nums[i-1],nums[i-1] + g[i-1]);gmin = Math.min(gmin,g[i]);//求数组中间的最小子数组和} //判断数组是否全为负数,如果是直接返回fmax,不是判断1,2情况哪个大return  sum==gmin ? fmax:Math.max(fmax,sum-gmin);}
}

 

http://www.yayakq.cn/news/781362/

相关文章:

  • 大学生活动网站开发文案四川建设工程招标信息网
  • 网站在线建设方案即墨建设局网站
  • 怎么建设阿里巴巴国际网站德州北京网站建设
  • 四川住房和城乡建设九大员网站网站优化客户报表
  • 苏州比较大的网站公司网站备案换接入商
  • 查看邮箱注册的网站wordpress 注册钩子
  • 北京一家专门做会所的网站简述程序开发的流程
  • 旅游网站模板htmlwordpress支付查看插件
  • 有模板如何做网站廊坊做网站优化
  • 广州网络帮助建站百度 营销推广多少钱
  • 福州建设网站效果个人网站备案材料
  • 自助建站上建的网站免费吗wordpress 百度推广
  • 湖南基础建设投资集团网站自己怎么手机做网站
  • 网站建设是指erp系统介绍
  • 网站实名认证怎么做吐鲁番好网站建设设计
  • 做网站需要哪些手续网站开发相关会议
  • 网站建设太金手指六六二八互联网保险现状
  • 本地电脑做视频网站 外网连接网站制作简单模版
  • 现在网站开发的前端语言房管局备案查询网站
  • 宏润建设网站网站域名和服务器到期
  • 网站分析 实例南京做网站建设的公司排名
  • 山东省建设厅执业资格注册中心网站wordpress 时间轴页面
  • 网站建设的好处工业设计工资一般多少
  • 做网站如何写需求wordpress 获取优酷
  • 社区子网站群建设有哪些做家教网站
  • 法律咨询网站建设方案电商网站模板下载
  • 贵阳做网站公司英茗网站建设
  • 做网站的外包需要分享客户信息外贸网站建设服务商
  • 电子商务网站建设交印花税吗对京东网站建设的总结
  • 网站开发从入门到精通最经济 网站建设