51nod(动态规划入门---最大子段问题)
2016-03-22 20:58
246 查看
题目:N个整数组成的序列a[1],a[2],a[3],…,a
,求该序列如a[i]+a[i+1]+…+a[j]的连续子段和的最大值。当所给的整数均为负数时和为0。
例如:-2,11,-4,13,-5,-2,和最大的子段为:11,-4,13。和为20。
输入
输出
输入示例
输出示例
代码如下:
,求该序列如a[i]+a[i+1]+…+a[j]的连续子段和的最大值。当所给的整数均为负数时和为0。
例如:-2,11,-4,13,-5,-2,和最大的子段为:11,-4,13。和为20。
输入
第1行:整数序列的长度N(2 <= N <= 50000) 第2 - N + 1行:N个整数(-10^9 <= A[i] <= 10^9)
输出
输出最大子段和。
输入示例
6 -2 11 -4 13 -5 -2
输出示例
20
代码如下:
#include<stdio.h> #include<algorithm> using namespace std; int main(){ int n,i,a; long long end,ans; scanf("%d",&n); scanf("%d",&a); end=ans=a; for(i=2;i<=n;i++){ scanf("%d",&a); if(end>0){ end+=a; } else end=a; ans=max(ans,end); } printf("%lld\n",ans); return 0; }
相关文章推荐
- NodeJS + PhantomJS 抓取页面信息以及截图
- ViewPager实现Fragment懒加载
- Bzoj3834:[Poi2014]Solar Panels:数论,分块
- Linux基础命令(持续更新中)
- eclipse中查看项目有多少行代码
- 软件工程
- iOS中使用工厂模式定制cell
- C++中的堆和栈的完全解析
- Android App的设计架构:MVC,MVP,MVVM与架构经验谈
- 蓝桥杯 2016c/c++A组 题解
- XListView实现下拉刷新和上拉加载
- JAVA hashcode和equals为何要同时重写
- c++第2次作业
- placeholder的样式设置
- Window系统下gvim编码中文乱码解决办法
- sizeof()一个空类
- 康拓展开模板
- 多线程(一)简介
- bzoj1076: [SCOI2008]奖励关
- RecyclerView使用详解(一)