连续子数组的最大乘积及连续子数组的最大和(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 | ...
随机推荐
- Django项目纪要
开发流程 公司高层 项目立项 | 市场部门 需求分析-->需求分析说明书, 需求规格说明书 | 产品部门 产品原型-->产品 UI 前端 后端 测试 移动端 | |------------ ...
- 安全漏洞XSS、CSRF、SQL注入以及DDOS攻击
随着互联网的普及,网络安全变得越来越重要,程序员需要掌握最基本的web安全防范,下面列举一些常见的安全漏洞和对应的防御措施. 0x01: XSS漏洞 1.XSS简介 跨站脚本(cross site s ...
- 【C++】C++中的类模板
基础的类模板 模板类的继承 内部声明定义普通模板函数和友元模板函数 内部声明友元模板函数+外部定义友元模板函数 声明和定义分别在不同的文件(模板函数.模板友元) C++中有一个重要特性,那就是模板类型 ...
- openwrt如何打开linux内核的CONFIG_DEVMEM选项?
答: 直接在openwrt的make menuconfig中打开CONFIG_KERNEL_DEVMEM选项即可
- github加速
访问 https://www.ipaddress.com/ 找到以下网址对应的ip,在本地hosts里面映射,或者到路由器内映射好即可. github.com assets-cdn.github.co ...
- 带有Q_OBJECT的类要放在头文件的第一个类位置,否则可能无法moc
如果头文件中有多个类,带有Q_OBJECT的类要放在头文件的第一个类位置,否则可能无法moc
- 新手學python之新體驗
1. 使用縮進方式做為程式塊開始結束的標示,程式換行在行末尾加 "\" 2. 元祖(Tuple)數據類型,和List的不同是Tuple不能修改,優點是執行速度比List快,因為不能 ...
- Xshell连接SqlPlus无法使用退格、删除键
问题:在使用xshell连接CentOS7,进入SQLPLUS进行命令操作时,如果输错了信息,无法进行退格键删除(显示“^H”),同样按删除键,显示“^[[3~”. 解决:网上查找了相关资料,可以通过 ...
- Spring的@Autowired和@Resource注入
@Autowired的原理 Spring@Autowired注解与自动装配 @Autowired 与@Resource的区别(详细) spring不但支持自己定义的@Autowired注解,还支持几个 ...
- python 异常处理(25)
在python开发中,代码书写时难免有疏忽或者意向不到的bug,导致程序run的过程中有可能会直接崩溃:然后对于程序猿而言,程序因bug崩溃是家常便饭,为了增加程序的健壮性,防止程序崩溃,我们可以对程 ...