最大子段和

最大子段和

最大子段和:给出一个数组,计算其中连续的最大的子段和


运行代码,及运行思想:

/** * 动态规划:计算最大子段和 * 算法描述: * 数组a 有n个元素, 记 s[i] 为从a【0】到a[i]中,包含a[i]的最大子段和 * 则: s[i] 的值为: s[i-1]>0时, s[i-1]+a[i] * 否则 a[i] */ #include <stdio.h> #include <stdlib.h>
int maxSub(int *a, int n) { int i=0, max=0, max_pos = 0; int si_1=0, si = 0;//分别记录s[i-1], 和 s[i]的值
    int *p = (int *)malloc(n*sizeof(int)); //p[i] 助于记录哪些单元被选择, p[i]=1 表示s[i]计算的结果中中使用了s[i-1]的值
    
    if (p==NULL) return -1; max = si_1 = a[0]; p[0] = 0; for (i=1; i<n; i++) { if (si_1<0) { p[i] = 0; si = a[i]; } else { p[i] = 1; si = si_1+a[i]; } si_1 = si; if (si>max) { max = si; max_pos = i; } } //找到最大子段和的位置
    for (i=max_pos; i>=0; i--) if (p[i]==0) break; //即i..max_pos为最大子段和的元素
    printf("%d--%d:%d\n", i, max_pos, max); free(p); p = NULL; return max; } int main() { int n = 10; int a[10] = {
    3, 5, 6, 10, -2, -5, 3, 5, -112, -324}; maxSub(a, n); return 0; }

源代码摘自:http://blog.csdn.net/chaoyue1216/article/details/6870339

运行结果:

最大子段和

最大子段和

转载于:https://my.oschina.net/u/204616/blog/545172

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/100865.html原文链接:https://javaforall.net

(0)
上一篇 2021年7月8日 下午8:00
下一篇 2021年7月8日 下午9:00


相关推荐

  • jQuery EasyUI+ashx实现数据库的CIUD操作

    jQuery EasyUI+ashx实现数据库的CIUD操作对上一个小项目做一个回顾总结,涉及到了jQueryEasyUI+ashx实现数据库的CIUD操作,和大家分享一下。基本思路是用easyui做前端,ashx做后端,中间使用json格式交换数据,其中json主要使用Newtonsoft.Json来序列化和反序列化,为简单起见,后端没有分层,数据都是靠拼接sql,使用一个简单封装的DBHelper来时间数据库的操作。1、数据库表tb_Provid

    2025年6月14日
    3
  • Spinnaker 高可用安装构思与实践

    Spinnaker 高可用安装构思与实践由于官方没有提供高可用的方案 官方直接建议由 K8S 进行调度 但是由于网络原因往往无法安装成功 生产环境如果是单点方案 死掉一个以后 恢复的时间由于网络原因时间会非常长 着急上线或者部署的话会出现很大的问题 Spinnaker 所有的配置文件由 minio 进行存储 Minio 高可用的话 可以解决存储的问题 但是还是不能解决 spinnaker 挂掉一个然后不影响使用的问题基本构思是 先安装一个 min

    2026年3月19日
    1
  • 寻路算法浅析

    寻路算法浅析很多游戏特别是 rts rpg 类游戏 都需要用到寻路 在游戏中 我们经常想找到从一个位置到另一位置的路径 我们不仅在寻找最短的距离 我们还希望考虑旅行时间 要找到此路径 我们可以使用图搜索算法 该算法在将地图表示为图时起作用 A 是图形搜索的流行选择 广度优先搜索是最简单的图形搜索算法 这篇文章会介绍广度游戏搜索 然后介绍 Dijkstra 算法 最后逐步提高到 A 目录 BFS 广度优先搜索 Dijkstra 算法贪婪优先搜索 A 星算法浅析与实践 A 星算法优化 B 星 todo 一 广度优先搜索 Br

    2026年3月17日
    2
  • mysql 获取当前时间数字_MySQL 获得当前日期时间(以及时间的转换)

    mysql 获取当前时间数字_MySQL 获得当前日期时间(以及时间的转换)MYSQL获取当前日期及日期格式获取系统日期:NOW()格式化日期:DATE_FORMAT(date,format)注:date:时间字段format:日期格式返回系统日期,输出2009-12-2514:38:59selectnow();输出09-12-25selectdate_format(now(),’%y-%m-%d’);根据format字符串格式化date值:%S,%…

    2026年4月15日
    3
  • Linux操作系统基础(完结)

    Linux操作系统基础(完结)一、Linux操作系统概述二、Linux操作系统安装三、Linux文件系统及文件基础四、Linux操作系统命令使用基础五、Linux应用程序的安装与卸载基础五、用户及进程六、相关信息查询七、网络配置八、Linux应用程序的安装与卸载基础九、vim

    2022年5月9日
    45
  • 在windows10机器上安装部署人脸识别/安全帽识别项目笔记

    在windows10机器上安装部署人脸识别/安全帽识别项目笔记在windows7机器上安装部署人脸识别/安全帽识别项目笔记1.Anaconda的安装配置从官网https://www.anaconda.com/download/下载Anaconda的安装程序,在该页面选择你电脑所对应的系统(Windows、macOSorLinux)以及操作系统位数(64位or32位)。至于是Python的版本是3.6还是2.7,这里推荐你使用Python3.6…

    2022年5月19日
    37

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号