博客
关于我
最大子数组和算法(Java实现)
阅读量:290 次
发布时间:2019-03-03

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

三种最大子数组和算法的Java实现和比较

代码于2018年12月12日重新更新了一下,因为之前代码上传时有部分丢失。这次,为了防止代码再丢失,我决定把源码的截图也贴上来(节选自《数据结构与算法分析——Java语言版》——Mark Allen Weiss 著 ---冯舜玺 译)。如下图:

第一种算法:运行时间为O(N^3),这完全取决于第13和14行,它们由一个含于三重嵌套for循环中的O(1)语句组成。第8行上的循环大小为N。

 第二种算法:运行时间为O(N^2)。

 第三种算法:运行时间为O(N log N)。

(1)Java代码

package com.sau.five.algorithmAnalysis;public class MaxSubsequenceSum {		public static int maxSubsequenceSum01(int[] a)  //方法1:时间复杂度n(o^3)	{		int maxSum=0;     //记录最大子数组和		for(int i=0;i
maxSum) { maxSum=thisSum; } } return maxSum; } public static int maxSubsequenceSum02(int[] a) //方法2:时间复杂度n(o^2) { int maxSum = 0; for (int i=0; i
maxSum) { maxSum = thisSum; } } } return maxSum; } public static int maxSubsequenceSum03(int[] a) //方法3:时间复杂度n(o) { int maxSum=0; int thisSum=0; for(int j = 0; j < a.length; j++){ thisSum += a[j]; if(thisSum > maxSum) { maxSum = thisSum; } else if(thisSum < 0) { thisSum = 0; } } return maxSum; } public static void main(String[] args) //main方法 { int L = 1000; //数组长度 long startTime00=System.nanoTime(); //获取程序开始时间 MaxSubsequenceSum mss = new MaxSubsequenceSum(); int[] a = new int[L]; for(int i=0;i
(2)三种算法运行结果比较
① 数组长度为1000时,运行结果如下图。比较三种算法的运行时间(单位:豪秒)约为 96.23:2.86:0.07,可见第三种算法的运行效率远高于前两种算法。
 
② 数组长度为10000时,运行结果如下图。比较三种算法的运行时间(单位:秒)约为 98.85:0.03:0.0003,而程序总运行时间也不过98.88秒,可见第一种算法几乎占用了程序运行的全部时间。

 

③ 数组长度为100000时,运行结果如下图。调换一下程序的运行顺序,比较三种算法的运行时间(单位:秒)约为   ∞:2.16:0.003,可见当数组长度达到10^6数量级时,第一种算法已经没有实用价值了惊恐

你可能感兴趣的文章
Vue3.0中的响应式原理(第九课)
查看>>
NIO蔚来 面试——IP地址你了解多少?
查看>>
NISP一级,NISP二级报考说明,零基础入门到精通,收藏这篇就够了
查看>>
NISP国家信息安全水平考试,收藏这一篇就够了
查看>>
NIS服务器的配置过程
查看>>
NIS认证管理域中的用户
查看>>
Nitrux 3.8 发布!性能全面提升,带来非凡体验
查看>>
NiuShop开源商城系统 SQL注入漏洞复现
查看>>
NI笔试——大数加法
查看>>
NLog 自定义字段 写入 oracle
查看>>
NLog类库使用探索——详解配置
查看>>
NLP 基于kashgari和BERT实现中文命名实体识别(NER)
查看>>
NLP 时事和见解【2023】
查看>>
NLP 模型中的偏差和公平性检测
查看>>
Vue3.0 性能提升主要是通过哪几方面体现的?
查看>>
NLP 项目:维基百科文章爬虫和分类【01】 - 语料库阅读器
查看>>
NLP_什么是统计语言模型_条件概率的链式法则_n元统计语言模型_马尔科夫链_数据稀疏(出现了词库中没有的词)_统计语言模型的平滑策略---人工智能工作笔记0035
查看>>
NLP、CV 很难入门?IBM 数据科学家带你梳理
查看>>
NLP三大特征抽取器:CNN、RNN与Transformer全面解析
查看>>
NLP入门(六)pyltp的介绍与使用
查看>>