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)的更多相关文章

  1. 【LeetCode】Maximum Product Subarray 求连续子数组使其乘积最大

    Add Date 2014-09-23 Maximum Product Subarray Find the contiguous subarray within an array (containin ...

  2. 152.Maximum Product Subarray---dp---连续子数组的最大乘积---《编程之美》2.13子数组的最大乘积

    题目链接:https://leetcode.com/problems/maximum-product-subarray/description/ 题目大意:给出一串数组,找出连续子数组中乘积最大的子数 ...

  3. 在win2008 r2主域控制域上打开“组策略管理”报错“未打开组策略对对象。你可能没有合适的权限”

    在win2008 r2主域控制域上打开“组策略管理”报错“未打开组策略对对象.你可能没有合适的权限” 打开组策略管理其它选项提示:找不到指定路径.之前做过的操作:取消域控主机上的共享目录sysvol和 ...

  4. sql server迁移数据(文件组之间的互相迁移与 文件组内文件的互相迁移)

    转自:https://www.cnblogs.com/lyhabc/p/3504380.html?utm_source=tuicool SQLSERVER将数据移到另一个文件组之后清空文件组并删除文件 ...

  5. sql 分组取每组的前n条或每组的n%(百分之n)的数据

    sql 分组取每组的前n条或每组的n%(百分之n)的数据 sql keyword: SELECT * ,ROW_NUMBER() OVER(partition by b.UserID order by ...

  6. 剑指Offer:面试题31——连续子数组的最大和(java实现)

    问题描述 : 输入一个整数数组,数组里面有正数也有负数.数组中一个或连续几个整数组成一个子数组.求所有子数组的和的最大值.要求时间复杂度为O(n) 思路1:常规解法,不知道怎么描述了.. 代码: bo ...

  7. 连续子数组的最大和 java实现

    package findMax; /** * 连续子数组的最大和 * @author root * */ public class FindMax { static int[] data = {1,- ...

  8. 洛谷-乘积最大-NOIP2000提高组复赛

    题目描述 Description 今年是国际数学联盟确定的“2000――世界数学年”,又恰逢我国著名数学家华罗庚先生诞辰90周年.在华罗庚先生的家乡江苏金坛,组织了一场别开生面的数学智力竞赛的活动,你 ...

  9. 查找至少连续出现三次的所有数字/连续3天的日期【LeetCode】

    编写一个SQL查询,查找至少连续出现三次的所有数字.+----+-----+ | Id | Num | +----+-----+ | 1 | 1 | | 2 | 1 | | 3 | 1 | | 4 | ...

随机推荐

  1. oracle通过dblink连接mysql配置详解(全Windows下)

    关于oracle通过dblink连接mysql,经过了两周的空闲时间研究学习,终于配置好了,真是不容易啊,仔细想想的话,其实也没花多长时间,就是刚开始走了一段弯路,所以把这次的经验分享出来,让大家少走 ...

  2. crc64

    oss2\models.py class PartInfo(object):     """表示分片信息的文件. 该文件既用于 :func:`list_parts < ...

  3. cesium地形瓦片(Quantized-mesh)格式

    目录 1.切片规则 2.瓦片格式分析 2.1.数据头部 2.顶点数据 2.3.索引数据 2.4.扩展数据 参考资料: quantized-mesh-1.0 terrain format(用于三维可视化 ...

  4. CRM 负责人 选择

    CRM 负责人 参与 - 搜狗搜索https://www.sogou.com/sgo?query=CRM+%E8%B4%9F%E8%B4%A3%E4%BA%BA+%E5%8F%82%E4%B8%8E& ...

  5. Embed MP4 in HTML using flash-player(html5 video player)

    https://stackoverflow.com/questions/1000851/embed-mp4-in-html-using-flash-player ******************* ...

  6. 【SpringBoot】SpringBoot日志框架(四)

    日志框架介绍 在开发过程中,我们经常使用到日志来进行排查问题,我们使用的日志框架都是由2部分组成(日志API + 日志实现) 日志API(及日志抽象层)有:SLF4j(Simple Logging F ...

  7. IDEA快捷键无法使用

    IDEA快捷键无法使用 觉得有用的话,欢迎一起讨论相互学习~Follow Me 今天新换了一台主机,但是很奇怪的是自己的IDEA快捷键使用不了了,以为是主机还是硬件的问题,最终解决后,发现是软件之间的 ...

  8. 拼接Sql语句小心得

    在往数据库插入数据时,需要根据数据和数据库中的列信息进行拼接,在本篇文章中,输出小心得.使用语言为 python. 拼接原始列信息 比如待插入数据库列信息为 deptNo,dName, Locate, ...

  9. pidstat 命令详解

    pidstat 概述 pidstat是sysstat工具的一个命令,用于监控全部或指定进程的cpu.内存.线程.设备IO等系统资源的占用情况.pidstat首次运行时显示自系统启动开始的各项统计信息, ...

  10. firewall详解

    官方文档介绍地址:https: //access.redhat.com/documentation/en-US/Red_Hat_Enterprise_Linux/7/html/Security_Gui ...