免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
楼主: davycu
打印 上一主题 下一主题

[算法] 迅雷笔试题 [复制链接]

论坛徽章:
0
1 [报告]
发表于 2010-09-19 15:22 |显示全部楼层
本帖最后由 lqglqy 于 2010-09-19 17:27 编辑

这样可以!还有更好的没啊?!!!!!求教~~~~~~
  1. #include    <stdlib.h>
  2. #include    <stdio.h>
  3. int max_array(int *p_a, int len)
  4. {
  5.     int max = 0;
  6.     int i,count=0;
  7.     int start = 0;
  8.     int end = 0;
  9.     for (i=0; i<len; i++) {
  10.         count += p_a[i];
  11.         if (count < 0) {
  12.             count = 0;
  13.             start = i+1;            
  14.         }   
  15.         if (count > max) {
  16.              max = count;
  17.              end = i+1;
  18.         }   
  19.     }   

  20.     printf("{");
  21.     for (;start<end;start++) {
  22.         printf("%d",p_a[start]);
  23.         if (start+1 < end)
  24.             printf(",");
  25.     }   
  26.     printf("}");
  27.     return max;

  28. }
  29. /*
  30. * ===  FUNCTION  ======================================================================
  31. *         Name:  main
  32. *  Description:  
  33. * =====================================================================================
  34. */
  35.     int
  36. main ( int argc, char *argv[] )
  37. {
  38.     int a[] = {9, -12, 120, 8, -20, 100, 30, -89, 20};
  39.     int max = max_array(a, sizeof(a)/sizeof(a[0]));
  40.     printf("=sum[%d]\n",max);
  41.     return EXIT_SUCCESS;

  42. }               /* ----------  end of function main  ---------- */
复制代码
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP