冒泡、插入、选择排序的时间复杂度为O(n2

Arrays.sort()时间复杂度为nlgn

具体算法实现代码:

 package recursion;

 import java.util.Arrays;

 /**
* @author zsh
* @company wlgzs
* @create 2019-02-17 9:46
* @Describe 冒泡、插入、选择排序与Arrays.sort()的性能差别
*/
public class Main3 { /**
* 冒泡排序
* @param arr 待排序的数组
* @return 已排序的数组
*/
static int[] bubbleSort(int[] arr){
//外层循环执行N-1趟
for (int i = 0; i < arr.length -1; i++) {
//内层循环执行N-1-i趟
for (int j = 0; j < arr.length -1 -i ; j++) {
//如果数组前一个元素比后一个元素的值大,交换
if (arr[j] > arr[j+1]){
int temp = arr[j+1];
arr[j+1] = arr[j];
arr[j] = temp;
}
}
}
return arr;
} /**
* insertSort(arr,k) 递归实现插入排序
* 找重复:insertSort(arr,k-1) 将k-1个排序后,把arr[k]插入到前面的数据中 --子问题
* 找变化:变化的量应该作为参数 k。
* 找边界:出口 终止的条件 k == 0
*/
static int[] insertSort(int[] arr,int k){
if (k == 0){
return arr;
}
//对前k-1个元素排序
insertSort(arr,k-1);
//把k位置上的元素插入到前面的部分
int x = arr[k];
int index = k -1;
while (index >= 0 && x <arr[index]){
arr[index+1] = arr[index];
index--;
}
arr[index+1] = x;
return arr;
} /**
* 选择排序
* @param arr 待排序的数组
* @return 已排序的数组
*/
static int[] selectionSort(int[] arr){
for (int i = 0; i < arr.length-1; i++) {
int k = i;
for (int j = i + 1; j < arr.length ; j++) {
if (arr[j] < arr[k]){
//记录此时找到最小值的位置
k = j;
}
}
//内层循环结束,找到最小值后进行交换
if (i != k){
int temp = arr[i];
arr[i] = arr[k];
arr[k] = temp;
}
}
return arr;
} public static void main(String[] args) {
//构造随机数组
int[] arr = new int[10000];
for (int i = 0; i < arr.length; i++) {
double a = Math.random()*10000;
arr[i] = (int) a;
}
//调用冒泡排序进行
long time1 = System.currentTimeMillis();
System.out.println(Arrays.toString(bubbleSort(arr)));
long time2 = System.currentTimeMillis();
System.out.println(time2-time1+"ms");
//调用插入排序进行(使用递归)
long time3 = System.currentTimeMillis();
System.out.println(Arrays.toString(insertSort(arr,arr.length-1)));
long time4 = System.currentTimeMillis();
System.out.println(time4-time3+"ms");
//调用选择排序进行
long time5 = System.currentTimeMillis();
System.out.println(Arrays.toString(selectionSort(arr)));
long time6 = System.currentTimeMillis();
System.out.println(time6-time5+"ms");
//调用Arrays.sort()进行
long time7 = System.currentTimeMillis();
Arrays.sort(arr);
long time8 = System.currentTimeMillis();
System.out.println(Arrays.toString(arr));
System.out.println(time8-time7+"ms");
} }

控制台输出:

经典算法分析:n^2与nlgn的更多相关文章

  1. 经典算法分析:n与lgn

    顺序查找O(n) 二分查找O(lgn) 通过代码来感受性能差别 package recursion; /** * @author zsh * @company wlgzs * @create 2019 ...

  2. Unity2017 经典游戏开发教程 算法分析与实现 (张帆 著)

    https://meta.box.lenovo.com/link/view/82c451b41ce34e81a4b34cb46747d3d5 第1章 熟悉Unity软件的操作 第2章 打地鼠 (已看) ...

  3. 【从零学习经典算法系列】分治策略实例——高速排序(QuickSort)

    在前面的博文(http://blog.csdn.net/jasonding1354/article/details/37736555)中介绍了作为分治策略的经典实例,即归并排序.并给出了递归形式和循环 ...

  4. 十大经典排序算法总结(JavaScript描述)

    前言 读者自行尝试可以想看源码戳这,博主在github建了个库,读者可以Clone下来本地尝试.此博文配合源码体验更棒哦~~~ 个人博客:Damonare的个人博客 原文地址:十大经典算法总结 这世界 ...

  5. Python数据结构与算法--算法分析

    在计算机科学中,算法分析(Analysis of algorithm)是分析执行一个给定算法需要消耗的计算资源数量(例如计算时间,存储器使用等)的过程.算法的效率或复杂度在理论上表示为一个函数.其定义 ...

  6. 阶乘之和 & 程序运行时间 & 算法分析

    实例:输入n,计算S = 1! + 2! + 3! + 4! + ... + n!的末六位(不含前导0).其中 n ≤ 106. 分析:考虑到数据溢出后程序如下: #include <stdio ...

  7. c语言入门教程 / c语言入门经典书籍

    用C语言开始编写代码初级:C语言入门必备(以下两本书任选一本即可) C语言是作为从事实际编程工作的程序员的一种工具而出现的,本阶段的学习最主要的目的就是尽快掌握如何用c语言编写程序的技能.对c语言的数 ...

  8. hdu 1043 Eight 经典八数码问题

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1043 The 15-puzzle has been around for over 100 years ...

  9. 【转】c语言入门教程 / c语言入门经典书籍

    用C语言开始编写代码 初级:C语言入门必备 (以下两本书任选一本即可) C语言是作为从事实际编程工作的程序员的一种工具而出现的,本阶段的学习最主要的目的就是尽快掌握如何用c语言编写程序的技能.对c语言 ...

随机推荐

  1. python快速开发Web之Django

    以前写测试框架,要么是纯python代码驱动的,要么是WinForm界面的框架,多人操作并不适合. 就想用python写个Web版的,于是想到了Web快速开发的框架Flask和Django两个 个人觉 ...

  2. 38.html----相对于父元素的fixed定位的实现

    之前在项目中,遇到了一个场景,需要实现相对于父元素的fixed定位:在父元素内拖动滚动条时,"fixed"定位的元素不能滑动,在外层拖动滚动条时,父元素及父元素内的所有元素跟着一起 ...

  3. NodeJs笔记 : express框架创建工程 ----- 路由设计

    一.搭建工程 1 .安装 express-generator $ npm install -g express-generator 2 .本地创建express项目 $ express -e blog ...

  4. 第一章 CSS基础

    1.CSS:层叠样式表 (1)好处:结构样式分离.样式复用.精确控制布局定位.方便搜索引擎搜索(2)用途:美化修饰.布局定位 2.CSS样式表使用方式(3种):(1)内嵌样式[行内样式]:确定到具体元 ...

  5. c# 在mongo中查询经纬度范围

    #region 索引 //IndexKeysDocument doc = new IndexKeysDocument();//新建索引 //2d 平面坐标索引,适用于基于平面的坐标计算.也支持球面距离 ...

  6. wordpress学习(四)---url伪静态简单了解

    在page-url.php页面做测试 <h2>url伪静态</h2> 接收到的pagename参数是:<? echo $wp_query->query_vars[' ...

  7. 内网渗透之如何玩转Meterpreter?(nc.exe)

    十.Meterpreter常用命令 1.基本命令(包含meterpreter和msf终端.ruby接口.目标shell交互的命令) background(进程隐藏至后台) sessions(查看已经成 ...

  8. 数据分析之Numpy库入门

    1.列表与数组 在python的基础语言部分,我们并没有介绍数组类型,但是像C.Java等语言都是有数组类型的,那python中的列表和数组有何区别呢? 一维数据:都表示一组数据的有序结构 区别: 列 ...

  9. hdu5439 二分

    题意 初始给了 1 2 两个数 第二步 因为第2个数是2 所以  在序列后面放上2个2 包括他自己之前有的 序列变成 1 2 2 第三步 因为第3个数是2 所以  在序列后面放上2个3 就变成了 1 ...

  10. SiteCore Experience Analytics-体验分析

    体验分析   Sitecore Experience Analytics为营销人员和营销分析师提供仪表板和报告,以识别从其网站和可能的其他外部数据源收集的体验数据的模式和趋势. 体验分析报告示例:   ...