编程算法 - 连续和最大的子数组 代码(C)
来源:互联网 发布:javascript 在线测试 编辑:程序博客网 时间:2024/05/19 18:42
连续和最大的子数组 代码(C)
本文地址: http://blog.csdn.net/caroline_wendy
题目: 在一个数组中, 找出连续和最大的子序列.
使用两个变量, 一个变量存储当前值, 一个变量存储最大值, 并设一个临时数组, 用于更新最大和数组.
时间复杂度O(n).
代码:
/* * main.cpp * * Created on: 2014.9.19 * Author: spike */#include <iostream>#include <vector>#include <climits>using namespace std;int FindSequence (int data[], int length, vector<int>& vi){if (data == NULL || length <= 0)return INT_MIN;int greatest = INT_MIN;int cur = 0;vector<int> tmp;for (int i=0; i<length; ++i) {if (cur <= 0) {cur = data[i];tmp.clear();tmp.push_back(data[i]);} else {cur += data[i];tmp.push_back(data[i]);}if (cur > greatest) {vi = tmp;greatest = cur;}}return greatest;}int main(void){int data[] = {1, -2, 3, 10, -4, 7, 2, -5};int length = sizeof(data)/sizeof(data[0]);vector<int> vi;int g = FindSequence(data, length, vi);cout << g << ": ";for (size_t i=0; i<vi.size(); ++i) {cout << vi[i] << " ";}cout << endl; return 0;}
输出:
18: 3 10 -4 7 2
4 0
- 编程算法 - 连续子数组的最大和 代码(C)
- 编程算法 - 连续和最大的子数组 代码(C)
- 【C++】数组中连续子数组的最大和
- 算法导论 - 最大和连续子数组
- 【算法】最大连续子数组和
- c/c++ 算法之求连续子数组的最大和
- 程序员编程艺术:求连续子数组的最大和
- Java编程----连续子数组的最大和
- 算法题:连续子数组的最大和
- 算法:求连续子数组的最大和
- 算法 (连续)子数组的最大和(及起始点)
- 面试算法(三十一)连续子数组的最大和
- [算法]求最大连续子数组和的PHP程序
- 算法复习:连续子数组的最大和
- 【算法】求连续子数组的最大和
- pyrhon--c++--连续子数组的最大和
- 数组连续子数组的和最大
- 数组连续子数组的最大和
- S5PC100——UART
- Highlight words in webbrowser control
- ST Nucleo mbed套件开发 一 MBED环境使用 以Nucleo-F401为例
- Cocos2d-x3.2与OpenGL渲染总结(一)Cocos2d-x3.2的渲染流程
- 松赞干布鎏金铜像
- 编程算法 - 连续和最大的子数组 代码(C)
- 《Android4游戏编程入门经典》读后感
- 黑马程序员——java小结_014.001_map+泛型输出
- Android使用java的Math.Random获取随机色值
- 【线段树】线段树入门
- 百度2015校园招聘笔试题——研发工程师(西安站)
- java基础知识
- android实现tab选项的方式
- c++中const用法整理