最大子序列和的接口函数(2)

举报
心跳包 发表于 2021/11/13 00:35:55 2021/11/13
【摘要】 int MaxSubsequenceSum(const int A[],int N){ int thisSum,MaxSum,i,j,k; MaxSum=0; for(i=1;i<N;i++) { for(j=i;j<N;j++) { thisSum=0; for(k=i;k<j;j++) { t...

  
  1. int MaxSubsequenceSum(const int A[],int N)
  2. {
  3. int thisSum,MaxSum,i,j,k;
  4. MaxSum=0;
  5. for(i=1;i<N;i++)
  6. {
  7. for(j=i;j<N;j++)
  8. {
  9. thisSum=0;
  10. for(k=i;k<j;j++)
  11. {
  12. thisSum+=A[K];
  13. }
  14. if(thisSum>MaxSum)
  15. MaxSum=thisSum;
  16. }
  17. return MaxSum
  18. }
  19. }

举个例子,在test.c中:


  
  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. int MaxSubsequenceSum(const int A[],int N)
  4. {
  5. int thisSum,MaxSum,i,j,k;
  6. MaxSum=0;
  7. for(i=0;i<N;i++)
  8. {
  9. printf("i:%d ....\n",i);
  10. for(j=i;j<N;j++)
  11. {
  12. printf("j:%d ....\n",j);
  13. thisSum=0;
  14. for(k=i;k<=j;k++)
  15. {
  16. printf("k:%d ....\n",k);
  17. thisSum+=A[k];
  18. }
  19. if(thisSum>MaxSum)
  20. MaxSum=thisSum;
  21. }
  22. }
  23. return MaxSum;
  24. }
  25. int main()
  26. {
  27. int number[]={1,-1,3,4};
  28. int maxsum=0;
  29. printf("start ....\n");
  30. maxsum=MaxSubsequenceSum(number,4);
  31. printf("maxsum:%d\n",maxsum);
  32. exit(0);
  33. }

linux下编译运行


  
  1. gcc -o sub maxsub.c
  2. ./sub

得出结果


  
  1. start ....
  2. i:0 ....
  3. j:0 ....
  4. k:0 ....
  5. j:1 ....
  6. k:0 ....
  7. k:1 ....
  8. j:2 ....
  9. k:0 ....
  10. k:1 ....
  11. k:2 ....
  12. j:3 ....
  13. k:0 ....
  14. k:1 ....
  15. k:2 ....
  16. k:3 ....
  17. i:1 ....
  18. j:1 ....
  19. k:1 ....
  20. j:2 ....
  21. k:1 ....
  22. k:2 ....
  23. j:3 ....
  24. k:1 ....
  25. k:2 ....
  26. k:3 ....
  27. i:2 ....
  28. j:2 ....
  29. k:2 ....
  30. j:3 ....
  31. k:2 ....
  32. k:3 ....
  33. i:3 ....
  34. j:3 ....
  35. k:3 ....
  36. maxsum:7

第一个for循环为N,第二个for循环大小为N-i;第三个for循环大小j-i+1;总数为O(1*N*N*N)=O(N^{3})

文章来源: xintiaobao.blog.csdn.net,作者:心跳包,版权归原作者所有,如需转载,请联系作者。

原文链接:xintiaobao.blog.csdn.net/article/details/89476888

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。