《编程之美》的一个问题

子善旬 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)

这个问题要怎么修改呢?谢谢大侠们了
...全文
213 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;
}
这里有另外一个代码,你可以参考对比一下,答案是一样的
vector0429 2012-11-22
  • 打赏
  • 举报
回复
最大和子数组就是去掉 x<0的数组三
breakfisher 2012-11-22
  • 打赏
  • 举报
回复
这个没问题吧,这个数组的最大和子数组就是其本身吧{3,2, -1, 2, 2}
内容概要:本文详细介绍了利用Simulink进行变压器开路试验的电路连接配置与仿真实现方法,重点在于通过仿真手段还原实际电力系统中变压器在空载条件下的电气特性,从而深入理解其工作原理与性能表现。文章作为电力系统仿真系列研究的一部分,系统阐述了从电路模型搭建、参数设定、仿真运行到结果分析的完整流程,突出展示了MATLAB/Simulink在电力设备建模与教学科研中的强大功能与应用价值。; 适合人群:具备电力系统基础知识,熟悉MATLAB/Simulink仿真环境,从事电气工程、自动化及相关领域的研发人员,以及高年级本科生和研究生。; 使用场景及目标:①掌握变压器开路试验的基本原理与Simulink仿真建模的具体步骤;②通过仿真实验深入理解空载电流、铁芯损耗及励磁特性等关键参数的物理意义;③为后续开展变压器短路试验、暂态过程分析以及其他电力设备的仿真研究奠定理论与实践基础。; 阅读建议:建议结合Simulink软件动手实践,逐步构建并调试电路模型,重点关注各元件参数的设置方法与测量模块的应用技巧,同时推荐参考文中提及的其他相关仿真案例进行拓展学习,以全面提升对电力系统仿真实践的整体认知与操作能力。

70,038

社区成员

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

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