分治法求最大子段和
时间:2020-05-21
本文章向大家介绍分治法求最大子段和,主要包括分治法求最大子段和使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
问题分析:(直接截的PPT)
代码如下:
1 #include <iostream> 2 #include <math.h> 3 using namespace std; 4 //寻找最大子段和 5 int MaxSum(int a[], int left, int right) { 6 int sum = 0, midsum = 0, leftsum = 0, rightsum = 0; 7 if (left == right) sum = a[left]; 8 else { 9 //划分 10 int center, lefts, rights, s1, s2, i; 11 center = (left + right) / 2; 12 leftsum = MaxSum(a, left, center); 13 rightsum = MaxSum(a, center+1, right); 14 //情况3 15 s1 = 0; 16 lefts = 0; 17 for (i = center; i >= left; i--) { 18 lefts = lefts + a[i]; 19 if (lefts > s1) s1 = lefts; 20 } 21 s2 = 0; 22 rights = 0; 23 for (i = center + 1; i <= right; i++) { 24 rights = rights + a[i]; 25 if (rights > s2) s2 = rights; 26 } 27 midsum = s1 + s2; 28 //寻找最大值 29 if (leftsum > rightsum) sum = leftsum; 30 else sum = rightsum; 31 if (sum < midsum) sum = midsum; 32 } 33 return sum; 34 } 35 int main() { 36 int a[10]; 37 cout << "请依次输入十个数" << endl; 38 int i, sum; 39 for (i = 0; i < 10; i++) cin >> a[i]; 40 cout << "输入完成!" << endl; 41 int left = 0, right = 9; 42 sum = MaxSum(a, left, right); 43 cout << "最大子段和为" << sum << endl; 44 return 0; 45 }
时间复杂度:O(nlog2n)
原文地址:https://www.cnblogs.com/2019-12-10-18ykx/p/12932101.html
- JMS + jboss EAP 6.2 示例
- Maven Compilation error [package org.testng.annotations does not exist]
- 查看jar包的jdk版本并降级
- ejb3: message drive bean(MDB)示例
- java提示找不到或无法加载主类
- 学Java有什么好方法?刻苦学技术让我最终成为自信的码农
- expect+scp传输文件发现文件丢失
- IBM WebSphere MQ 7.5基本用法
- QPS的计算
- Django----中间件详解
- linux 添加用户到sudo中
- 机器学习之白话adaboost元算法
- 查看占用内存多的进程
- jboss EAP 6.2 + Message Drive Bean(MDB) 整合IBM Webshpere MQ 7.5
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- 从零搭建Spring Boot脚手架(5):整合 Mybatis Plus
- SQL Server数据库阻塞,死锁查询
- 如何优雅地写出大规模线性规划的对偶
- 数据库char varchar nchar nvarchar,编码Unicode,UTF8,GBK等,Sql语句中文前为什么加N(一次线上数据存储乱码排查)
- [Maven][maven-shade-plugin]告警[WARNING] maven-shade-plugin has detected that some class files are pre
- asp.net core 3.1多种身份验证方案,cookie和jwt混合认证授权
- 只知道java反射,宁知道内省吗?
- JDK1.8新特性(七):默认方法,真香,开动!接口?我要升级!!
- Windows10上安装Linux子系统(WSL2,Ubuntu),配合Windows Terminal使用,还要什么自行车
- [Maven][maven-site-plugin]告警[WARNING] No project URL defined - decoration links will not be relativi
- QListWidget添加删除
- 使用GitHub Actions编译项目并将Jar发布到Maven Central仓库
- 为啥Flutter Hooks没有受到太多关注和青睐?
- 二叉搜索树删除节点 动画演示
- 并发与竞态 (自旋锁)