《编程之美》的一个问题

子善旬 2012-11-22 06:33:22
《编程之美》书上186页的一段程序,求数组的子数组之和的最大值,我把它放入vs调试


#include "stdafx.h"
#include "windows.h"

int max1(int x,int y)
{
return (x>y)?x:y;
}
int _tmain(int argc, _TCHAR* argv[])
{
int a[]={3,2,-1,2,2};
int n=5, i;
int start[5],all[5];

start[n-1]=a[n-1];
all[n-1]=a[n-1];

for(i=n-2;i>=0;i--) {
start[i] = max1(a[i],a[i]+start[i+1]);
all[i] = max1(start[i],all[i+1]);
}

for(i=0;i<n;i++) printf("%d ",start[i]);
printf("\n");

for(i=0;i<n;i++) printf("%d ",all[i]);
printf("\n");

system("pause");
return 0;
}


结果不对啊,输出如下:
8 5 3 4 2
8 5 4 4 2
请按任意键继续. . .

书上说,all[0]就是最大和,运算为8,但实际是5(3+2)

这个问题要怎么修改呢?谢谢大侠们了
...全文
147 6 打赏 收藏 转发到动态 举报
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
子善旬 2012-11-23
  • 打赏
  • 举报
回复
引用 1 楼 breakfisher 的回复:
这个没问题吧,这个数组的最大和子数组就是其本身吧{3,2, -1, 2, 2}
看了这个回答,才转过弯,可以所有的都加起来,。。。。
prajna 2012-11-22
  • 打赏
  • 举报
回复
引用 1 楼 breakfisher 的回复:
这个没问题吧,这个数组的最大和子数组就是其本身吧{3,2, -1, 2, 2}
同意!
newtee 2012-11-22
  • 打赏
  • 举报
回复
breakfisher 2012-11-22
  • 打赏
  • 举报
回复
#include<stdio.h>

int MaxSum2(int *A, int n)
{
  int nStart = A[n-1];
  int nAll = A[n-1];    
  int i ;
  for(i = n-2;i>=0;--i)
  {
    if(nStart<0)
      nStart = 0;
    nStart += A[i];
    if(nStart>=nAll)
    {
      nAll = nStart;           
    }
  }
  return nAll;
}
int main()
{
  int a[]={3,2,-1,2,2};
  int n=5, i;
  int start[5],all[5];

  printf("result: %d\n", MaxSum2(a, 5));
  return 0;
}
这里有另外一个代码,你可以参考对比一下,答案是一样的
yfl819586803 2012-11-22
  • 打赏
  • 举报
回复
最大和子数组就是去掉 x<0的数组三
breakfisher 2012-11-22
  • 打赏
  • 举报
回复
这个没问题吧,这个数组的最大和子数组就是其本身吧{3,2, -1, 2, 2}

69,371

社区成员

发帖
与我相关
我的任务
社区描述
C语言相关问题讨论
社区管理员
  • C语言
  • 花神庙码农
  • 架构师李肯
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧