ACM第三次练习—1001
来源:互联网 发布:淘宝代销合同 编辑:程序博客网 时间:2024/05/16 06:36
题意:给出序列a [1], a [2], a [3] ...... a [n],计算子序列的最大总和。
思路:最大子序列是要找出由数组成的一维数组中和最大的连续子序列。方法是:只要前i项和还没有小于0子序列就一直往后扩展,否则丢弃之前的子序列开始新的子序列,同时记录各个子序列的和,最后取他们中的最大值。
感想:第一道动态规划题,感觉要考虑的东西很多,脑子有些不都用了~
代码:
#include<stdio.h>
int main()
{
int i,ca=1,t,s,e,n,x,now,before,max;
scanf("%d",&t);
while(t--)
{
scanf("%d",&n);
for(i=1;i<=n;i++)
{
scanf("%d",&now);
if(i==1)
{
max=before=now;
x=s=e=1;
}
else {
if(now>now+before)
{
before=now;
x=i;
}
else before+=now;
}
if(before>max)
max=before,s=x,e=i;
}
printf("Case %d:\n%d %d %d\n",ca++,max,s,e);
if(t)printf("\n");
}
return 0;
}
- ACM第三次练习—1001
- ACM第三次练习—1002
- ACM第三次练习—1003
- ACM第三次练习—1004
- ACM第三次练习—1005
- ACM第三次练习—1006
- ACM第三次练习—1010
- ACM第三次练习—1011
- ACM第三次练习—1015
- ACM第三次练习—1012
- ACM第三次练习—1013
- ACM第三次练习—1014
- ACM第三次练习—1016
- ACM第三次练习—1017
- ACM第三次练习—1007
- ACM第三次练习—1010
- 第三次练习
- ACM第二次练习—1001
- apt-get update: Not Found [IP: 91.189.92.152 80]
- UIScrollView基本使用(一)
- 75、myeclipse配置jdk
- 函数名与函数指针
- 高精度加法运算-Java语言描述
- ACM第三次练习—1001
- MySQL 5.7新特性的学习
- 各种int的范围
- CSU oj 1726 你经历过绝望吗?两次!(bfs+优先队列求最短路)
- XMG 偏好设置存储
- 寄存器和存储器的区别?
- 利用java自动生成验证码
- 【HUSTOJ】1005: 位数对调
- WEB-INF 有关的目录路径问题总结