01-复杂度2 Maximum Subsequence Sum (25分)

#include<iostream>
#include<algorithm>
#include<cstring>
#include<string>
#include<cstdio>
#include<cctype>
#include<cmath>
#include<vector>
#include<set>
#include<map>
#include<sstream>
#define mm(a,x) memset(a,x,sizeof(a))

using namespace std;
typedef long long ll;
const int INF=0x3f3f3f3f;
const int maxn=10005;


int main() {
   
	int first,last,temp;
	int thismax,thissum;
	int a[maxn];
	int n;
	cin>>n;
	for(int i=0;i<n;i++)
	cin>>a[i];
	thissum=0;
	thismax=-1;
	for(int i=0;i<n;i++)
	{
   
		thissum+=a[i];
		if(thissum>thismax)
		{
   
			thismax=thissum;
			first=temp;
			last=i;
		}
		else if(thissum<0)
		{
   
			thissum=0;
			temp=i+1;
		}
	}
	if(thismax>=0)
	cout<<thismax<<" "<<a[first]<<" "<<a[last]<<endl;
	else{
   
		cout<<0<<" "<<a[0]<<" "<<a[n-1];
	}
}
全部评论

相关推荐

03-03 23:12
已编辑
北京邮电大学 Java
书海为家:我来给一点点小建议,因为毕竟还在学校不像工作几年的老鸟有丰富的项目经验,面试官在面试在校生的时候更关注咱们同学的做事逻辑和思路,所以最好在简历中描述下自己做过项目的完整过程,比如需求怎么来的,你对需求的解读,你想到的解决办法,遇到困难如何找人求助,最终项目做成了什么程度,你从中收获了哪些技能,你有什么感悟。
你的简历改到第几版了
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务