最长子序列和的问题非常easy:

就是一个数组,求出当中当中连续的某一段和,而这一段和是全部的连续段和的最大的值。求出这个值。

先说复杂度最高的:O(n3)

直接上代码,非常easy的:

//
// main.cpp
// SumSequence
//
// Created by Alps on 14-7-23.
// Copyright (c) 2014年 chen. All rights reserved.
// #include <iostream>
using namespace std; int MaxSubsequenceSum(const int A[], int N){
int ThisSum, MaxSum, i, j, k;
MaxSum = 0;
for(i = 0; i < N; i++){
for(j = i; j < N; j++){
ThisSum = 0;
for (k = i; k < j; k++) {
ThisSum += A[k];
}
MaxSum = ThisSum > MaxSum ? ThisSum: MaxSum;
}
}
return MaxSum;
} int main(int argc, const char * argv[])
{ int A[] = {1, 2, -5, 2, 5, 1, 8, -4};
int N = sizeof(A)/sizeof(int);
// printf("%d\n",N);
int MaxSum = MaxSubsequenceSum(A, N);
printf("%d\n",MaxSum);
return 0;
}

这个事实上非常easy,第一层for循环是i从头開始遍历。第二层for是j从i遍历到尾。第三层就是算i到j的这一段的和。

时间复杂度是O(n3).

以下说一个O(n2)的:

代码例如以下:

//
// main.cpp
// SumSequencen2
//
// Created by Alps on 14-7-23.
// Copyright (c) 2014年 chen. All rights reserved.
// #include <iostream>
using namespace std; int MaxSubSequenceSum(const int A[], int N){
int MaxSum, ThisSum, i, j;
MaxSum = 0;
for (i = 0; i < N; i++) {
ThisSum = 0;
for (j = i; j < N; j++) {
ThisSum += A[j];
MaxSum = MaxSum > ThisSum ? MaxSum : ThisSum;
}
}
return MaxSum;
} int main(int argc, const char * argv[])
{
int A[] = {1, 2, -5, 2, 5, 1, 8, -4};
int N = sizeof(A)/sizeof(int);
// printf("%d\n",N);
int MaxSum = MaxSubSequenceSum(A, N);
printf("%d\n",MaxSum); return 0;
}

这个也比較好理解,第一层循环就是i从头到尾遍历,第二层循环是j从i遍历到尾,在遍历过程中不断检測ThisSum的大小,取Max(ThisSum, MaxSum)的数,并赋值给MaxSum,这样就能够知道MaxSum是多少了~

另一个方法复杂度是O(nlogn)可是这个算法比較麻烦,代码也比較麻烦,我这里没有写~想学的能够去《数据结构与算法分析》来学习。

这里有一个O(n)级别的算法来解决问题!!!:请看代码:

//
// main.cpp
// SumSequencen
//
// Created by Alps on 14-7-23.
// Copyright (c) 2014年 chen. All rights reserved.
// #include <iostream> using namespace std; int MaxSubSequenceSum(const int A[], int N){
int MaxSum, ThisSum, i;
MaxSum = A[0];
ThisSum = 0;
for (i = 0; i < N; i++) {
ThisSum += A[i];
MaxSum = ThisSum > MaxSum ? ThisSum: MaxSum;
if (ThisSum < 0) {
ThisSum = 0;
continue;
}
}
return MaxSum;
} int main(int argc, const char * argv[])
{
int A[] = {1, 2, -5, 2, 5, 1, 8, -4};
int N = sizeof(A)/sizeof(int);
// printf("%d\n",N);
int MaxSum = MaxSubSequenceSum(A, N);
printf("%d\n",MaxSum);
return 0;
}

O(n)级别的这类算法算是比較完美的算法了。我对这个算法的理解就是,在一个数组里,有非常多非常多段,这些段都有一个和,最小的段是一个元素,而最大的序列和肯定是一个段,或者是两个段的和,和就是加上一个正数就变大,所以当一个段是负数的时候,我就直接抛弃掉了~(除非全部都是负数,就找一个最大的。)

所以就有了上面的算法。。不懂的请留言~

算法-最长子序列和C/C++实现(三个复杂度)的更多相关文章

  1. nyoj 17-单调递增最长子序列 && poj 2533(动态规划,演算法)

    17-单调递增最长子序列 内存限制:64MB 时间限制:3000ms Special Judge: No accepted:21 submit:49 题目描述: 求一个字符串的最长递增子序列的长度 如 ...

  2. 算法:Common Subsequence(动态规划 Java 最长子序列)

    Description A subsequence of a given sequence is the given sequence with some elements (possible non ...

  3. 最长递增子序列问题 nyoj 17单调递增最长子序列 nyoj 79拦截导弹

    一,    最长递增子序列问题的描述 设L=<a1,a2,…,an>是n个不同的实数的序列,L的递增子序列是这样一个子序列Lin=<aK1,ak2,…,akm>,其中k1< ...

  4. HDU 1513 最长子序列

    Palindrome Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total ...

  5. HDU 4123 (2011 Asia FZU contest)(树形DP + 维护最长子序列)(bfs + 尺取法)

    题意:告诉一张带权图,不存在环,存下每个点能够到的最大的距离,就是一个长度为n的序列,然后求出最大值-最小值不大于Q的最长子序列的长度. 做法1:两步,第一步是根据图计算出这个序列,大姐头用了树形DP ...

  6. 【LCS,LIS】最长公共子序列、单调递增最长子序列

    单调递增最长子序列 时间限制:3000 ms  |  内存限制:65535 KB 难度:4   描述 求一个字符串的最长递增子序列的长度如:dabdbf最长递增子序列就是abdf,长度为4   输入 ...

  7. nyoj 17 单调递增最长子序列

    单调递增最长子序列 时间限制:3000 ms  |  内存限制:65535 KB 难度:4   描述 求一个字符串的最长递增子序列的长度如:dabdbf最长递增子序列就是abdf,长度为4   输入 ...

  8. NYOJ17,单调递增最长子序列

    单调递增最长子序列 时间限制:3000 ms  |  内存限制:65535 KB 难度:4 描写叙述 求一个字符串的最长递增子序列的长度 如:dabdbf最长递增子序列就是abdf.长度为4 输入 第 ...

  9. 隐马尔科夫模型HMM(二)前向后向算法评估观察序列概率

    隐马尔科夫模型HMM(一)HMM模型 隐马尔科夫模型HMM(二)前向后向算法评估观察序列概率 隐马尔科夫模型HMM(三)鲍姆-韦尔奇算法求解HMM参数(TODO) 隐马尔科夫模型HMM(四)维特比算法 ...

随机推荐

  1. c显示数字的LED(数字转LED)

    实现这么一个函数:传入一个int值,在屏幕输出类似LED显示屏效果的字母拼图,例如: 输入1234567890,输出: 请注意每个字符的固定宽度和高度,两个数字间保留一个空格. 函数名:void LE ...

  2. python pythonic是什么?

    原文地址:http://faassen.n--tree.net/blog/view/weblog/2005/08/06/0 注:Martijn 是 Zope 领域的专家,他为 Zope 系列产品做了许 ...

  3. 杭电 HDU 1242 Rescue

    http://acm.hdu.edu.cn/showproblem.php?pid=1242 问题:牢房里有墙(#),警卫(x)和道路( . ),天使被关在牢房里位置为a,你的位置在r处,杀死一个警卫 ...

  4. socket.io+angular.js+express.js做个聊天应用(四)

    接着上一篇 使用angularjs构建聊天室的client <!doctype html> <html ng-app="justChatting"> < ...

  5. Java集合中对象排序

    集合中的对象排序需求还是比較常见的.当然我们能够重写equals方法,循环比較:同一时候Java为我们提供了更易使用的APIs.当须要排序的集合或数组不是单纯的数字型时,通常能够使用Comparato ...

  6. 案例分析:java中substring引发的Full gc

    问题定位 由于应用频繁地Full gc,就dump了内存下来用MAT分析,发现有个map占用了98%的内存,于是找到这个map private ConcurrentMap<String, Str ...

  7. win32下利用python操作printer

    在win32下操作printer:   1)import win32print   2) 获得默认打印机名:          >>> win32print.GetDefaultPr ...

  8. iOS: 在键盘之上显示一个 View

    如 AlertView,当 show 一个 Alert 时,它会覆盖在 Keyboard 上面,不影响显示的效果.那么我们自己创建的 View 如何像 Alert 那样不被键盘盖住呢?很简单,拿到 A ...

  9. Windows Phone 8初学者开发—第17部分:Coding4Fun工具包简介

    原文 Windows Phone 8初学者开发—第17部分:Coding4Fun工具包简介 第17部分:Coding4Fun工具包简介 原文地址:  http://channel9.msdn.com/ ...

  10. 给centOs添加epel源

    epel简介: https://fedoraproject.org/wiki/EPEL/zh-cn 1. rpm -Uvh http://dl.fedoraproject.org/pub/epel/5 ...