连续子数组的最大乘积及连续子数组的最大和(Java)
1. 子数组的最大和
输入一个整形数组,数组里有正数也有负数。数组中连续的一个或多个整数组成一个子数组,每个子数组都有一个和。求所有子数组的和的最大值。例如数组:arr[]={1, 2, 3, -2, 4, -3 } 最大子数组为 {1, 2, 3, -2, 4} 和为8。
解法1(时间复杂度O(N * N)空间复杂度O(1))
求出所有的子数组的和,比较选择出最大值。利用双重循环就可以遍历到所有的子数组。
public static void maxSum1(int arr[]) {
int max=0,sum;
for(int i=0;i<arr.length;i++)
{
sum=0;
for(int j=i;j<arr.length;j++)
{
//遍历数组的所有子数组,并将子数组的最大和保存在max中。
sum+=arr[j];
max=Math.max(max, sum);
//max保存最大的子数组的和
}
}
System.out.println(max);
}
解法2(动态规划时间复杂度O(N)空间复杂度O(1))
遍历数组,用 sum 保存子数组的和,当 sum<0 时 将 arr[i] 赋值给 sum,用 max 保存最大值。
public static void maxSum(int arr[]){
int max=0,sum=0;
for(int i=0;i<arr.length;i++)
{
if(sum<=0){
sum=arr[i];
//如果 sum<0 重新赋值
} else {
sum+=arr[i];
}
max=Math.max(sum, max);
//将最大值保存在max中。
}
System.out.println(max);
}
2. 子数组的最大乘积
输入一个整形数组,数组里有正数也有负数。数组中连续的一个或多个整数组成一个子数组,每个子数组都有一个和。求所有子数组的和的最大值。例如数组:arr[]={1, 2, 3, -2, 4, 3 } 最大子数组为 {4,3} 积为12。
解法1(时间复杂度O(N * N)空间复杂度 O(1))
跟上面求最大子数组的和类似,利用双重循环遍历所有的子数组,求出所有子数组中值最大的。
public static void maxproduct(int arr[]){
if(arr==null||arr.length==0)
return;
//如果数组为 null 或者长度为0直接返回
int max=0,product=1;
//max保存子数组的最大乘积,product 用来保存每一个子数组的积
for(int i=0;i<arr.length;i++) {
product=1;
for(int j=i;j<arr.length;j++){
product*=arr[j];
max=Math.max(product, max);
//max保存最大的子数组乘积
if(product==0)
break;
//如果当前子数组的乘积为0则以当前数组为头的后序数组的积全为0不用求。
}
}
System.out.println(max);
}
解法2(动态规划 时间复杂度O(N )空间复杂度 O(1))
跟上面求最大子数组的和类似,利用双重循环遍历所有的子数组,求出所有子数组中值最大的。以arr[i] 结尾的最大值可能由前面的以arr[i-1]结尾的 最大 负值,最大正数,和arr[i] 产生。例如数组:{2,-3,-4}以-4结尾的最大值,就是3*2=-6,与-4 相乘产生的。
public static void maxSubProduct(int arr[]){
if(arr==null||arr.length==0)
return ;
int max=arr[0],min=arr[0],maxend,result=0;
for(int i=1;i<arr.length;i++) {
//最大值的来源有三种,如果arr[i]是正数,肯定与前面的最大值相乘得到最大值,
//如果arr[i]是负数就会与前面的最小值相乘产生最大值。如果前面的为0或者负数,
//arr[i]本身可能是最大值。
maxend=Max(max*arr[i],min*arr[i],arr[i]);
//maxend 保存最大值
min=Min(max*arr[i], min*arr[i], arr[i]);
//用于保存最小的负值,为下一个最大值最准备
max=maxend;
result=Math.max(result, max);
}
System.out.println(result);
} public static int Max(int a,int b,int c)
{
//返回 a b c 中的最大值
a=Math.max(a, b);
a=Math.max(a, c);
return a;
}
public static int Min(int a,int b,int c)
{
//返回 a b c 中的最小值
a=Math.min(a, b);
a=Math.min(a, c);
return a;
}https://blog.csdn.net/u013309870/article/details/70144135
转自:笔试面试算法经典--连续子数组的最大乘积及连续子数组的最大和(Java)
连续子数组的最大乘积及连续子数组的最大和(Java)的更多相关文章
- 【LeetCode】Maximum Product Subarray 求连续子数组使其乘积最大
Add Date 2014-09-23 Maximum Product Subarray Find the contiguous subarray within an array (containin ...
- 152.Maximum Product Subarray---dp---连续子数组的最大乘积---《编程之美》2.13子数组的最大乘积
题目链接:https://leetcode.com/problems/maximum-product-subarray/description/ 题目大意:给出一串数组,找出连续子数组中乘积最大的子数 ...
- 在win2008 r2主域控制域上打开“组策略管理”报错“未打开组策略对对象。你可能没有合适的权限”
在win2008 r2主域控制域上打开“组策略管理”报错“未打开组策略对对象.你可能没有合适的权限” 打开组策略管理其它选项提示:找不到指定路径.之前做过的操作:取消域控主机上的共享目录sysvol和 ...
- sql server迁移数据(文件组之间的互相迁移与 文件组内文件的互相迁移)
转自:https://www.cnblogs.com/lyhabc/p/3504380.html?utm_source=tuicool SQLSERVER将数据移到另一个文件组之后清空文件组并删除文件 ...
- sql 分组取每组的前n条或每组的n%(百分之n)的数据
sql 分组取每组的前n条或每组的n%(百分之n)的数据 sql keyword: SELECT * ,ROW_NUMBER() OVER(partition by b.UserID order by ...
- 剑指Offer:面试题31——连续子数组的最大和(java实现)
问题描述 : 输入一个整数数组,数组里面有正数也有负数.数组中一个或连续几个整数组成一个子数组.求所有子数组的和的最大值.要求时间复杂度为O(n) 思路1:常规解法,不知道怎么描述了.. 代码: bo ...
- 连续子数组的最大和 java实现
package findMax; /** * 连续子数组的最大和 * @author root * */ public class FindMax { static int[] data = {1,- ...
- 洛谷-乘积最大-NOIP2000提高组复赛
题目描述 Description 今年是国际数学联盟确定的“2000――世界数学年”,又恰逢我国著名数学家华罗庚先生诞辰90周年.在华罗庚先生的家乡江苏金坛,组织了一场别开生面的数学智力竞赛的活动,你 ...
- 查找至少连续出现三次的所有数字/连续3天的日期【LeetCode】
编写一个SQL查询,查找至少连续出现三次的所有数字.+----+-----+ | Id | Num | +----+-----+ | 1 | 1 | | 2 | 1 | | 3 | 1 | | 4 | ...
随机推荐
- 《Maven实战》整理
一.maven介绍 Maven是优秀的构建工具,能够帮我们自动化构建过程,从清理.编译.测试到生成报告,再到打包和部署. Maven能帮助我们标准化构建过程.在Maven之前,十个项目可能有十种构建方 ...
- How to receive a million packets per second
Last week during a casual conversation I overheard a colleague saying: "The Linux network stack ...
- 线程:Java中wait、notify、notifyAll使用详解
基础知识 首先我们需要知道,这几个都是Object对象的方法.换言之,Java中所有的对象都有这些方法. public final native void notify(); public final ...
- 我的Mac上有哪些软件
工具 Pycharm CE GoLand Chrome 微信 网易云音乐 有道云笔记 iTerm Postman Sublime Text bashrc配置(支持显示git branch以及详细路径信 ...
- 010 vue使用render方法渲染组件
1.普通的组件渲染方式 <!DOCTYPE html> <html lang="en"> <head> <meta charset=&qu ...
- tomcat高并发优化的参数优化并查看tomcat线程数
在Tomcat配置文件conf下面 server.xml 中的配置中和连接数相关的参数有: minProcessors:最小空闲连接线程数,用于提高系统处理性能,默认值为10 maxProcessor ...
- ios 报错 Invalid row height provided by table delegate. Value must be at least 0.0, or UITableViewAutomaticDi......
Invalid row height provided by table delegate. Value must be at least 0.0, or UITableViewAutomaticDi ...
- nodejs相关框架
sails https://sailsjs.com/documentation/concepts koa koa 是由 Express 原班人马打造的,致力于成为一个更小.更富有表现力.更健壮的 ...
- Android Camera2/HAL3
Android : Camera2/HAL3 框架分析 https://www.cnblogs.com/blogs-of-lxl/p/10651611.html Android : Camera之ca ...
- maven项目中更新了核心库后导致一些包提示未定义,如:The import org.json cannot be resolved
经查看发现了原因,因为核心库的版本没有变更,本地仓库只更新了核心库的jar部分的库,没有更新核心库pom项目.从而导致了一些库的引用提示未定义. 以后有新库更新,最好在本地库删除全部的相关库,再mav ...