最大子段和问题(C/C++)
Description
给定有n个整数(可能为负整数)组成的序列a1,a2,...,an,求该序列连续的子段和的最大值。 如果该子段的所有元素和是负整数时定义其最大子段和为0。
Input
第一行有一个正整数n(n<1000),后面跟n个整数,绝对值都小于10000。直到文件结束。
Output
输出它的最大子段和。
Sample Input
6 -2 11 -4 13 -5 -2
Sample Output
20
参考: https://blog.csdn.net/niteip/article/details/7444973#
穷举法 时间复杂度:$O(n^3)$
/*O(n^3)*/
#include <stdio.h>
#include <stdlib.h> int main()
{
int n;
int num[1001];
int i, j, k;
int sum, max;
while (~scanf("%d", &n))
{
for (i = 0; i < n; i++)
scanf("%d", &num[i]);
max = 0;
for (i = 0; i < n; i++)
{
for (j = i; j < n; j++)
{
sum = 0;
for (k = i; k <= j; k++)
sum += num[k];
if (sum > max)
max = sum;
}
}
printf("%d\n", max);
}
return 0;
}
穷举法
时间复杂度:$O(n^2)$
/*O(n^2)*/
#include <stdio.h>
#include <stdlib.h> int main()
{
int n;
int num[1001];
int i, j, k;
int sum, max;
while (~scanf("%d", &n))
{
for (i = 0; i < n; i++)
scanf("%d", &num[i]);
max = 0;
for (i = 0; i < n; i++)
{
sum = 0;
for (j = i; j < n; j++)
{
sum += num[j];
if (sum > max)
max = sum;
}
}
printf("%d\n", max);
}
return 0;
}
分治法
时间复杂度:$O(nlog_2n)$
/*O(nlogn)分治法*/
#include <iostream>
#include <cstdio>
#include <cstdlib> int maxSubSegSum(int num[], int left, int right)
{
int mid = (left + right) / 2; if (left == right)
return num[left] > 0 ? num[left] : 0; int leftMaxSum = maxSubSegSum(num, left, mid);
int rightMaxSum = maxSubSegSum(num, mid + 1, right); int sum = 0;
int leftSum = 0;
for (int i = mid; i >= left; i--)
{
sum += num[i];
if (sum > leftSum)
leftSum = sum;
} sum = 0;
int rightSum = 0;
for (int i = mid + 1; i <= right; i++)
{
sum += num[i];
if (sum > rightSum)
rightSum = sum;
} int retSum = leftSum + rightSum;
if (retSum < leftMaxSum)
retSum = leftMaxSum;
if (retSum < rightMaxSum)
retSum = rightMaxSum;
return retSum;
} int main()
{
int n;
int num[1001]; while (~scanf("%d", &n))
{
for (int i = 0; i < n; i++)
scanf("%d", &num[i]);
printf("%d\n", maxSubSegSum(num, 0, n - 1));
}
return 0;
}
动态规划
时间复杂度:$O(n)$
/*O(n) 动态规划*/
#include <stdio.h>
#include <stdlib.h>
#include <memory.h> int main()
{
int n;
int num[1001];
int f[1001 + 1];
int i;
int max;
while (~scanf("%d", &n))
{
for (i = 1; i <= n; i++)
scanf("%d", &num[i]);
max = 0;
memset(f, 0, sizeof(f));
for (i = 1; i <= n; i++)
{
if (f[i - 1] > 0)
f[i] = f[i - 1] + num[i];
else
f[i] = num[i];
if (f[i] > max)
max = f[i];
}
printf("%d\n", max);
}
return 0;
}
或者
/*O(n) 动态规划*/
#include <stdio.h>
#include <stdlib.h>
#include <memory.h> int main()
{
int n;
int num[1001];
int b;
int i;
int max;
while (~scanf("%d", &n))
{
for (i = 1; i <= n; i++)
scanf("%d", &num[i]);
max = 0;
b = 0;
for (i = 1; i <= n; i++)
{
b = b > 0 ? b + num[i] : num[i];
max = b > max ? b : max;
}
printf("%d\n", max);
}
return 0;
}
最大子段和问题(C/C++)的更多相关文章
- 最大子段和(c++)
// 最大子段和.cpp : 定义控制台应用程序的入口点. // #include "stdafx.h" #include<iostream> using namesp ...
- 51Node 1065----最小正子段和
51Node 1065----最小正子段和 N个整数组成的序列a[1],a[2],a[3],…,a[n],从中选出一个子序列(a[i],a[i+1],…a[j]),使这个子序列的和>0,并且这 ...
- 最大M子段和 V2
51nod1053 这题还是我们熟悉的M子段和,只不过N,M<=50000. 这题似乎是一个堆+链表的题目啊 开始考虑把所有正数负数锁在一起. 比如: 1 2 3 -1 –2 -3 666 缩成 ...
- 51nod 循环数组最大子段和
http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1050 对于普通的数组,只要求一次最大子段和即可.但是这题是可以循环的,所 ...
- [日常训练]最大M子段和
Description 在长度为的序列中选出段互不相交的子段,求最大字段和. Input 第一行两个整数. 第二行个整数. Output 一行一个整数表示最大值. Sample Input 5 2 1 ...
- 51nod1049(计算最大子段和)
题目链接:http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1049 题意:又是仲文题诶- 思路:暴力会超时,又好像没什么专门 ...
- XCOJ 1103 (LCA+树链最大子段和)
题目链接: http://xcacm.hfut.edu.cn/problem.php?id=1103 题目大意:链更新.链查询,求树链的最大子段和.(子段可以为空) 解题思路: 将所有Query离线存 ...
- 洛谷P1121 环状最大两段子段和
题目描述 给出一段环状序列,即认为A[1]和A[N]是相邻的,选出其中连续不重叠且非空的两段使得这两段和最大. 输入输出格式 输入格式: 输入文件maxsum2.in的第一行是一个正整数N,表示了序列 ...
- [51NOD1959]循环数组最大子段和(dp,思路)
题目链接:http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1050 这道题的最大子段和有两种可能,一种是常规的子段和,另一种 ...
- 转载:最大子段和问题(Maximum Interval Sum)
一.问题描述 给定长度为n的整数序列,a[1...n], 求[1,n]某个子区间[i , j]使得a[i]+…+a[j]和最大.或者求出最大的这个和. 例如(-2,11,- ...
随机推荐
- docker容器学习资料
现在说起docker容器,你应该不会太陌生了吧?如果你是真的不懂或者是太久没有用到已经忘记的差不多了,那么你需要这一波的干货了,这波的干货刚刚好可以满足你的需要! 话不多说,直接上干货
- 使用Socket通信(一)
使用socket需要一个服务器,我用的是tomcat,好像AS不支持Tomcat了,还有什么好的服务器求推荐,使用Tomcat去官网下载,然后还要安装Java的jdk,然后配置jak环境变量,然后配置 ...
- windows7 安装配置NodeJS、NPM
转载自https://blog.csdn.net/dengxw00/article/details/82974808 windows7 安装配置NodeJS.NPM一.安装 NodeJS1.登陆官网( ...
- C2. Power Transmission (Hard Edition) 解析(思維、幾何)
Codeforce 1163 C2. Power Transmission (Hard Edition) 解析(思維.幾何) 今天我們來看看CF1163C2 題目連結 題目 給一堆點,每兩個點會造成一 ...
- 十八般武艺玩转GaussDB(DWS)性能调优(三):好味道表定义
摘要:表结构设计是数据库建模的一个关键环节,表定义好坏直接决定了集群的有效容量以及业务查询性能,本文从产品架构.功能实现以及业务特征的角度阐述在GaussDB(DWS)的中表定义时需要关注的一些关键因 ...
- Java学习的第二十一天
1.综合实例 error异常:error指的是错误,通常是程序员不可能通过代码来解决的问题,底层环境或硬件问题,也就是说在程序中用户不用捕获error及任何error子类的异常. exception指 ...
- Object of type Decimal is not JSON serializable
json遇到Decimal 型数据无法正确处理 解决方案 import json result = [ {'name': '小红', 'age': 26, 'balance': decimal.Dec ...
- Linux杂谈:进程锁核+实时线程导致的读写锁死循环
发现问题 公司项目测试的时候,发现运行一段时间后会出现cpu百分之百的情况. 想着可能是哪里出现了死循环,于是打算用gdb跟一下,结果gdb居然无法attach到进程...... 定位问题 查了查去, ...
- adb、package及activity
1. adb adb连接手机参考:https://www.cnblogs.com/mind18/p/12592252.html,中的三.5节 1.1. adb介绍 ADB全名Andorid De ...
- 红帽6.9搭建yum源的2种方式(HTTP和本地)
方式一:HTTP搭建 1.首先删除本身所带的yum `rpm -qa | grep yum | xargs rpm -e --nodeps ` #忽略依赖关系,强行删除 若出现 错误出现 将后面的 ...