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

东莞营销网站建设哪个平台好市场营销的十大理论

东莞营销网站建设哪个平台好,市场营销的十大理论,江阴网站建设公司,宁波网页美工培训文章目录 一、题目二、C# 题解 一、题目 给定一个整数数组,找出总和最大的连续数列,并返回总和。 示例: 输入: [-2,1,-3,4,-1,2,1,-5,4] 输出: 6 解释: 连续子数组 [4,-1,2,1] 的和最大,为 6。…

文章目录

  • 一、题目
  • 二、C# 题解

一、题目

  给定一个整数数组,找出总和最大的连续数列,并返回总和。

示例:

输入: [-2,1,-3,4,-1,2,1,-5,4]
输出: 6
解释: 连续子数组 [4,-1,2,1] 的和最大,为 6。

进阶:

  • 如果你已经实现复杂度为 O(n) 的解法,尝试使用更为精妙的分治法求解。

  点击此处跳转题目。

二、C# 题解

  使用动态规划可以实现 O(n) 的复杂度。使用 max 记录以 j 结尾的最大连续和,其递推关系为:

m a x [ j ] = M A X { m a x [ j − 1 ] + n u m s [ j ] , n u m s [ j ] > 0 m a x [ j − 1 ] , n u m s [ j ] ≤ 0 n u m s [ j ] , m a x [ j − 1 ] < 0 max[j]= MAX\left\{ \begin{array}{l l} max[j-1]+nums[j],&nums[j]>0\\ max[j-1],&nums[j]\leq0\\ nums[j],&max[j-1]<0 \end{array} \right. max[j]=MAX max[j1]+nums[j],max[j1],nums[j],nums[j]>0nums[j]0max[j1]<0

  每次纳入 nums[j] 并考虑:

  • max < 0,则直接从 j 开始就好,即设置 max = 0。因为算上前面的序列,和只会更小。
  • max += nums[j],与 ans 比较,ans 结果取最大值。

  理论上需要开辟一个 O(n) 数组存储 max,但是由于只需要求 max 的最大值 ans,因此可以边计算边更新 ans,省去了 O(n) 的空间。

public class Solution {public int MaxSubArray(int[] nums) {int ans = nums[0], max = ans;for (var j = 1; j < nums.Length; j++) {if (max < 0) max = 0;     // 先前的序列如果 < 0,则直接抛弃,从第 j 位开始重新计数max += nums[j];           // 并入第 j 位if (max > ans) ans = max; // 更新结果}return ans;}
}
  • 时间:84 ms,击败 61.11% 使用 C# 的用户
  • 内存:38.23 MB,击败 77.78% 使用 C# 的用户

  使用分治可以实现 O(logn) 的复杂度。将数组 nums 一分为二,记为 left 和 right。则 nums 的答案 Max 可能有如下 3 中情况:

  1. 在 left 中。
  2. 在 right 中。
  3. 在 left 和 right 交界处。

  因此,需要记录区间的左端最大连续和 LMax(红色) 与右端最大连续和 RMax(黄色),其对应的更新情况如下:

  • LMax:
  • RMax:

      同时,使用 Sum(绿色)记录区间的总长度。
public class Solution {public struct Range{public int LMax; // 从左端开始的最长连续和public int RMax; // 以右端结尾的最长连续和public int Sum;  // 区间总和public int Max;  // 区间内最长连续和public Range(int l, int r, int s, int m) {LMax = l;RMax = r;Sum = s;Max = m;}public static Range operator +(Range left, Range right) {int lMax = Math.Max(left.LMax, left.Sum + right.LMax);int rMax = Math.Max(right.RMax, left.RMax + right.Sum);int sum  = left.Sum + right.Sum;int max  = Math.Max(Math.Max(left.Max, right.Max), left.RMax + right.LMax);return new Range(lMax, rMax, sum, max);}}public int MaxSubArray(int[] nums) {return Partition(nums, 0, nums.Length - 1).Max;}public Range Partition(int[] nums, int i, int j) {if (i == j) return new Range(nums[i], nums[i], nums[i], nums[i]);int mid = (i + j) >> 1;return Partition(nums, i, mid) + Partition(nums, mid + 1, j);}
}
  • 时间:76 ms,击败 94.44% 使用 C# 的用户
  • 内存:38.25 MB,击败 77.78% 使用 C# 的用户
http://www.yayakq.cn/news/415985/

相关文章:

  • 述建设一个网站的具体步骤天津特定网站建设推广
  • 网站ui设计软件怎么选择扬中网站建设
  • 东营做网站优化多少钱当下最火的加盟店
  • 怎样做好网站建设青岛李沧区城乡建设局网站
  • 一起做网店的网站做游戏特效的网站
  • 帮企网站建设免费做淘宝客网站有哪些
  • 全屋定制十大名牌排行最新网站seo运营培训机构
  • 常见的网站开发语言备案域名出售是否违法
  • 购物网站大全论文网站建设目标
  • 找公司网站建设3椒江网站制作
  • 最好的国际贸易网站西安异构国际设计
  • 免费注册网站免登录WordPress最快主题
  • 小学网站建设实施方案吉林长春seo网站建设网站优化
  • 网站 不 备案新机发布最新消息
  • 郑州网站建设氵汉狮网络创意营销案例
  • iis配置网站无法浏览wordpress悬浮小人
  • 医院证明p图软件在线网站图片加载 优化
  • 怎样注册自己网站的域名做网站建设销售辛苦吗
  • 重庆永川建设银行网站重庆住房和城乡建设厅官方网站
  • 上海模板建站哪家好牛商网网站源码
  • 境外网站icp备案品牌策划公司的市场
  • 浙江公司网站建设推广wordpress 安装语言包
  • 东城做网站wordpress给用户发消息
  • 搜狗网站推广wordpress+软件+入门
  • 麻涌做网站免费域名网站申请
  • 广州市国外网站建设平台wordpress微信底部导航
  • 搭建网站的企业做网站一般都是那些人 会做
  • 中国建设教育网站jsp网站开发中js的问题
  • 云南公司网站开发手机微网站第二年续费吗
  • 西安的网站设计公司名称珠海网站建设专线