【第一周】最大子列和问题整理

2024-05-13 17:48

本文主要是介绍【第一周】最大子列和问题整理,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目地址:01-1. 最大子列和问题

算法一:暴力,直接计算出所有子列和,然后比较,显然复杂度炸裂,O(N^3)

int MaxSubseqSum1(int A[],int N)
{int ThisSum;int MaxSum = 0;int i,j,k;for (i = 0; i < N; ++i)//i是子列左端的位置{for (j = i; j < N; ++j)//j是子列右端的位置{ThisSum = 0;//A[i]到A[j]的子列和for (k = i; k < j ; ++k){ThisSum += A[k];if (ThisSum > MaxSum){MaxSum = ThisSum;}}}}return MaxSum;
}

算法二:优化第三层循环,将复杂度降到O(N^2)

int MaxSubseqSum2(int A[],int N)
{int ThisSum;int MaxSum = 0;int i,j;for (i = 0; i < N; ++i)//i是子列左端的位置{ThisSum = 0;//A[i]到A[j]的子列和for (j = i; j < N; ++j)//j是子列右端的位置{	ThisSum += A[j];//对于相同的i,不同的j,只要在j-1的基础上累加上1项即可if (ThisSum > MaxSum){MaxSum = ThisSum;}}}return MaxSum;
}

算法三:分而治之,把数组从中间分成两部分,然后递归地解决左右两边,最后考虑跨越边界的最大值。

复杂度的推算:



int MaxSubseqSum3(int A[],int x,int y)
{if (y-x==1){return A[x];}int mid = x+(y-x)/2;int leftSum = 0;int rightSum = 0;int leftMaxValue = A[m-1];int rightMaxValue = A[m];int i;int maxValue=max(MaxSubseqSum3(a,x,m),MaxSubseqSum3(a,m,y));for (i = mid - 1; i >= x; --i){leftSum += A[i];leftMaxValue = max(leftMaxValue,leftSum);}for (i = m; i < y; ++i){rightSum += A[i];rightMaxValue = max(rightMaxValue,rightSum);}return max(maxValue,leftMaxValue+rightMaxValue);}

算法四:在线处理,达到理想的复杂度了,O(N)

int MaxSubseqSum4(int A[],int N)
{int ThisSum,MaxSum;int i;ThisSum = MaxSum = 0;for (i = 0; i < N; ++i){ThisSum += A[i];//向右累加if (ThisSum > MaxSum){MaxSum = ThisSum;}else if (ThisSum < 0){ThisSum = 0;}}return MaxSum;
}

=============================================

最后AC的代码:

#include <cstdio>using namespace std;#define MAXN 100000
int main()
{freopen("in.txt","r",stdin);int list[MAXN];int n,i,;int ThisSum, MaxSum;int head,tail;scanf("%d",&n);int start = 0,end = n-1;for (int i = 0; i < n; ++i){scanf("%d",&list[i]);}	ThisSum = MaxSum = 0;for (int i = 0; i < n; ++i){if (ThisSum >=0){ThisSum += list[i];tail = i;}else{ThisSum = list[i];head = i;tail = i;}if (ThisSum > MaxSum ||(ThisSum == 0 && MaxSum == 0)){MaxSum = ThisSum;start = head;end = tail;}}printf("%d %d %d\n",MaxSum, list[start], list[end]);return 0;
}




这篇关于【第一周】最大子列和问题整理的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/986402

相关文章

CentOS系统使用yum命令报错问题及解决

《CentOS系统使用yum命令报错问题及解决》文章主要讲述了在CentOS系统中使用yum命令时遇到的错误,并提供了个人解决方法,希望对大家有所帮助,并鼓励大家支持脚本之家... 目录Centos系统使用yum命令报错找到文件替换源文件为总结CentOS系统使用yum命令报错http://www.cppc

使用@Slf4j注解,log.info()无法使用问题

《使用@Slf4j注解,log.info()无法使用问题》在使用Lombok的@Slf4j注解打印日志时遇到问题,通过降低Lombok版本(从1.18.x降至1.16.10)解决了问题... 目录@Slf4androidj注解,log.info()无法使用问题最后解决总结@Slf4j注解,log.info(

好题——hdu2522(小数问题:求1/n的第一个循环节)

好喜欢这题,第一次做小数问题,一开始真心没思路,然后参考了网上的一些资料。 知识点***********************************无限不循环小数即无理数,不能写作两整数之比*****************************(一开始没想到,小学没学好) 此题1/n肯定是一个有限循环小数,了解这些后就能做此题了。 按照除法的机制,用一个函数表示出来就可以了,代码如下

hdu1043(八数码问题,广搜 + hash(实现状态压缩) )

利用康拓展开将一个排列映射成一个自然数,然后就变成了普通的广搜题。 #include<iostream>#include<algorithm>#include<string>#include<stack>#include<queue>#include<map>#include<stdio.h>#include<stdlib.h>#include<ctype.h>#inclu

购买磨轮平衡机时应该注意什么问题和技巧

在购买磨轮平衡机时,您应该注意以下几个关键点: 平衡精度 平衡精度是衡量平衡机性能的核心指标,直接影响到不平衡量的检测与校准的准确性,从而决定磨轮的振动和噪声水平。高精度的平衡机能显著减少振动和噪声,提高磨削加工的精度。 转速范围 宽广的转速范围意味着平衡机能够处理更多种类的磨轮,适应不同的工作条件和规格要求。 振动监测能力 振动监测能力是评估平衡机性能的重要因素。通过传感器实时监

缓存雪崩问题

缓存雪崩是缓存中大量key失效后当高并发到来时导致大量请求到数据库,瞬间耗尽数据库资源,导致数据库无法使用。 解决方案: 1、使用锁进行控制 2、对同一类型信息的key设置不同的过期时间 3、缓存预热 1. 什么是缓存雪崩 缓存雪崩是指在短时间内,大量缓存数据同时失效,导致所有请求直接涌向数据库,瞬间增加数据库的负载压力,可能导致数据库性能下降甚至崩溃。这种情况往往发生在缓存中大量 k

数论入门整理(updating)

一、gcd lcm 基础中的基础,一般用来处理计算第一步什么的,分数化简之类。 LL gcd(LL a, LL b) { return b ? gcd(b, a % b) : a; } <pre name="code" class="cpp">LL lcm(LL a, LL b){LL c = gcd(a, b);return a / c * b;} 例题:

6.1.数据结构-c/c++堆详解下篇(堆排序,TopK问题)

上篇:6.1.数据结构-c/c++模拟实现堆上篇(向下,上调整算法,建堆,增删数据)-CSDN博客 本章重点 1.使用堆来完成堆排序 2.使用堆解决TopK问题 目录 一.堆排序 1.1 思路 1.2 代码 1.3 简单测试 二.TopK问题 2.1 思路(求最小): 2.2 C语言代码(手写堆) 2.3 C++代码(使用优先级队列 priority_queue)

poj 3723 kruscal,反边取最大生成树。

题意: 需要征募女兵N人,男兵M人。 每征募一个人需要花费10000美元,但是如果已经招募的人中有一些关系亲密的人,那么可以少花一些钱。 给出若干的男女之间的1~9999之间的亲密关系度,征募某个人的费用是10000 - (已经征募的人中和自己的亲密度的最大值)。 要求通过适当的招募顺序使得征募所有人的费用最小。 解析: 先设想无向图,在征募某个人a时,如果使用了a和b之间的关系

poj 3258 二分最小值最大

题意: 有一些石头排成一条线,第一个和最后一个不能去掉。 其余的共可以去掉m块,要使去掉后石头间距的最小值最大。 解析: 二分石头,最小值最大。 代码: #include <iostream>#include <cstdio>#include <cstdlib>#include <algorithm>#include <cstring>#include <c