最大子序列和
来源:互联网 发布:mac怎么看系统 编辑:程序博客网 时间:2024/05/18 09:53
三种最大子序列和问题解法
#include<stdio.h>
int MaxsubseqSum4(int A[],int N);
int MaxsubseqSum1(int B[],int n);
//最大子列和
int main()
{
int a[8]={-1,3,-2,4,-6,1,6,-1};
int k,i;
k=8;
k=MaxsubseqSum4(a,k);
printf("%d",k);
k=MaxsubseqSum1(a,k);
printf("%d",k);
return 0;
}
int MaxsubseqSum4(int A[],int k) //最优解法,只用一层循环,从第一个开始小于零丢弃,只遍历一次就能得出最大子序列和。
{
int Maxsum,thissum;
int i;
thissum=0;
Maxsum=0;
for(i=0;i<k;i++)
{
thissum+=A[i];
if(thissum>Maxsum)
Maxsum=thissum;
else if(thissum<0)
thissum=0;
}
printf("%d",Maxsum);
return Maxsum;
}
int MaxsubseqSum1(int B[],int k)
{
int ThisSum,Maxsum=0;
//三层嵌套for循环 时间复杂度n^3。 很麻烦。 先从0加到最后 再从1加到最后 。。。。如果i=1,j=3 那么 thissum=a1+a2+a3 j=4 重复(a1+a2+a3)+a4
int i,j,l;
for(i=0;i<k;i++)
{
for(j=i;j<k;j++)
for(l=i;l<j;l++)//第三次
{
ThisSum+=B[l];
if(ThisSum>Maxsum)
Maxsum=ThisSum; //
}
}
return Maxsum;
}
int MaxsubseqSum2(int B[],int k) //递推
{
int thissum,maxsum=0;
int j,i;
for(i=0;i<k;i++)
{
thissum=0;
for(j=i;j<k;j++)
{
thissum+=B[j]; // 3 -5 8 -7 6 //递推将上面的进行了优化 Sum(i,j)=sum(i,j-1)+aj 通过这个公式,减少了一层for循环。
if(thissum>maxsum) //
maxsum=thissum;
}
}
}
- 最大子序列和
- 最大子序列和
- 最大和子序列
- 最大子序列和
- 最大子序列和
- 最大子序列和
- 最大子序列和
- 最大子序列和?
- 最大子序列和
- 最大子序列和
- 和最大子序列
- 最大子序列和
- 最大子序列和
- 最大子序列和
- 最大子序列和
- 最大子序列和
- 最大和子序列
- 最大子序列和
- 练习题 No.4 字典序最小问题(贪心法)
- java中volatile和synchronized区别
- 蓄水池采样算法(Reservoir Sampling)
- ZOJ1525&&POJ1422&&HDU1151-Air Raid
- 结构体数组字节数大小
- 最大子序列和
- NetCore 1.0 Release 下载
- 江湖风云录-洛阳金刀门
- 1. Spring--容器
- 使用通配符配置action
- LeetCode 315. Count of Smaller Numbers After Self
- bootstrap学习笔记(2)--json数据处理(图书列表)
- centos7安装mysql
- 如何更新 OpenStack 组件?- 每天5分钟玩转 OpenStack(161)