博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
返回一个数组 最大子数组的和
阅读量:4455 次
发布时间:2019-06-08

本文共 923 字,大约阅读时间需要 3 分钟。

要求:

要求程序必须能处理1000 个元素;

每个元素是int32 类型的,出现子数组之和大于整型表示的最大范围会出现什么情况;

输入一个整形数组,数组里有正数也有负数。

数组中连续的一个或多个整数组成一个子数组,每个子数组都有一个和。

求所有子数组的和的最大值。要求时间复杂度为O(n)。

 

思路:

既然老师让这个程序能够处理1000个数,我们不妨用随机数srand函数随机生成

1000个随机数,考虑到有负数的存在,我们为数组加入负数,然后通过一个for循环

来将得到的和数赋值给MAX。最后判断MAX与各个元素的大小,如果MAX小于某个元素,则把这个值赋值给MAX。

 

遇到的问题:

因为没有学习过C++,很多程序语句不会写,借鉴了同学的代码。编程思路很乱。

#include <iostream>

#include<stdlib.h>
#include<time.h>
using namespace std;

int main()
{
int i;
int a[1000];
int max = 0;
int b = 0;
srand(time(NULL));
cout<<"数组为:"<<endl;
for (i = 0; i<1000; i++)
{
a[i] = rand()%2001-1000;
}
for (i = 0; i<1000; i++)
{
cout << a[i] << '\t';
}
cout << endl;
for (i = 0; i < 1000; i++)
{
b += a[i];
if (b < 0)
b = 0;
if (b > max)
max = b;
}
if (max == 0)
{
max = a[0];
for (i = 0; i < 1000; i++)
{
if (max < a[i])
{
max = a[i];
}
}
cout <<"最大子数组和为:"<< max << endl;
system("pause");
return 0;
}

运行结果:

帅照:

 

转载于:https://www.cnblogs.com/ljw199106m/p/9787134.html

你可能感兴趣的文章
高精度练习之乘法(codevs_3117)
查看>>
小Z爱划水
查看>>
Qt Font
查看>>
2014年生日
查看>>
扫描目录下的文件并拼接在一起
查看>>
ELK 分布式日志处理 10.12
查看>>
Java虚拟机详解05----垃圾收集器及GC参数
查看>>
7. 单位,移动布局
查看>>
inux中bin与sbin目录的作用及区别介绍
查看>>
USACO 3.1 Contact
查看>>
Office之什么是高内聚低耦合
查看>>
一些奇怪的问题求回答
查看>>
这些年踩过的坑
查看>>
iOS开发拓展篇——如何把项目托管到GitHub
查看>>
性能优化之数据库优化
查看>>
类的继承、菱形继承、派生、多态
查看>>
mysql约束
查看>>
javascript鼠标及键盘事件总结及案例
查看>>
mysql表之间的关系及级联操作
查看>>
mac 搭建virtualenv的那些坑
查看>>