本篇文章,先从数据结构开始,一边总结,一边反思,寻求最优解。

本文简单温习下最基础的三类算法:选择,冒泡,插入。先定义一个交换数组作为备用:

/**

* 交换数组元素

* @param arr

* @param a

* @param b

*/

public static void swap(int []arr,int a, int b){

arr[a] = arr[a] + arr[b];

arr[b] = arr[a] - arr[b];

arr[a] = arr[a] - arr[b];

}

注意:以下排序均为从小到大排序

1.简单选择排序

选择排序包括简单选择排序和堆排序,这里先介绍简单选择排序。

简单选择排序的基本思想:假设排序表为L[1...n],第i趟排序即从L[i...n]中选择关键字最小的元素与L(i)交换,每一趟排序可以确定一个元素的最终位置,这样经过n-1趟排序就可以使整个排序表有序。

简单选择排序算法的java代码实现如下:

/**

* 简单选择排序

* @param A

* @param n

*/

public static void selectSort(int A[],int n){

        for(int i=0;i<n-1;i++){      //一共进行n-1趟

             int min = i;             //记录最小元素的值

             for(int j=i+1;j<n;j++){  //在A[i...n-1]中选择最小的元素

                  if(A[j]<A[min]){     //更新最小元素位置

min = j;

}

}

             if(min!=i){

                 swap(A,i,min);       //与第i个位置交换

}

}

}

简单选择排序的性能分析如下:

空间效率:仅使用常数个辅助单元,故而空间效率为O(1)。

时间效率:从以上代码可以看出,元素移动的次数很少,但元素间的比较次数与序列的初始状态无关,始终是n(n-1)/2次,所以时间复杂度始终是O(n∧2).

稳定性:在第i趟找到最小元素后,和第i个元素交换,可能会导致第i个元素与其含有相同关键字元素的相对位置发生改变。因此,简单选择排序是不稳定的排序方法。

2.冒泡排序

    冒泡排序是交换排序的一种,交换排序还包括快速排序(以后再介绍)。

冒泡排序的基本思想是,对相邻的元素进行两两比较,顺序相反则进行交换,这样,每一趟会将最小或最大的元素“浮”到顶端,最终达到完全有序。

冒泡排序算法的java代码实现如下:

/**

* 冒泡排序

* @param A

* @param n

*/

public static void bubbleSort(int A[],int n){

       for(int i=0;i<n-1;i++){

             boolean flag = false;    //表示本趟冒泡是否发生交换的标志

             for(int j=n-1;j>i;j--){  //一趟冒泡过程

                   if(A[j-1]>A[j]){     //若为逆序

                        swap(A,j-1,j);   //交换

flag = true;

}

              if(flag == false){

                   return;          //本趟遍历后没有发生交换,说明表已经有序

}

}

}

}

冒泡排序的性能分析如下:

空间效率:仅使用常数个辅助单元,故而空间效率为O(1)。

时间效率:时间复杂度始终是O(n∧2).(老生常谈了,具体过程就不赘述了)

稳定性:由于当i>j且A[i]=A[j]时,不会交换两个元素,从而冒泡排序是一个稳定的排序方法。

3.直接插入排序

插入排序包括直接插入排序,折半插入排序和希尔排序,这里先介绍直接插入排序。

直接插入排序基本思想是每一步将一个待排序的记录,插入到前面已经排好序的有序序列中去,直到插完所有元素为止。

直接插入排序算法的java代码实现如下:

/**

* 插入排序

*

* @param arr

*/

public static void insertionSort(int[] arr,int n) {

for (int i = 1; i < n; i++) {

int j = i;

while (j > 0 && arr[j] < arr[j - 1]) {

swap(arr,j,j-1);

j--;

}

}

}

直接插入的性能分析如下:

空间效率:仅使用常数个辅助单元,故而空间效率为O(1)。

时间效率:时间复杂度始终是O(n∧2).

稳定性:由于当i>j且A[i]=A[j]时,不会交换两个元素,从而直接插入排序是一个稳定的排序方法。

java学习总结篇二--3 种简单排序的更多相关文章

  1. 【Java学习笔记之二十六】深入理解Java匿名内部类

    在[Java学习笔记之二十五]初步认知Java内部类中对匿名内部类做了一个简单的介绍,但是内部类还存在很多其他细节问题,所以就衍生出这篇博客.在这篇博客中你可以了解到匿名内部类的使用.匿名内部类要注意 ...

  2. 从.Net到Java学习第二篇——IDEA and start spring boot

    从.Net到Java学习第一篇——开篇 所谓工欲善其事,必先利其器,做java开发也一样,在比较了目前最流行的几个java IDE(eclipse,myeclipse.IDEA)之后,我果断选择IDE ...

  3. Java学习-028-JSON 之二 -- 数据读取

    JSON数据由 JSONObject.JSONArray.key_value 组合而成.通常来说,JSONObject 可以包含 JSONObject.JSONArray.key_value:JSON ...

  4. 从.Net到Java学习第一篇——开篇

    以前我常说,公司用什么技术我就学什么.可是对于java,我曾经一度以为“学java是不可能的,这辈子不可能学java的.”结果,一遇到公司转java,我就不得不跑路了,于是乎,回头一看N家公司交过社保 ...

  5. MongoDB学习:(二)MongoDB简单使用

    MongoDB学习:(二)MongoDB简单使用 MongoDB使用: 执行mongodb的操作之前,我们需要运行命令,来进入操作命令界面 >mongo 提示该错误,说明我们系统缺少一个补丁,该 ...

  6. 从.Net到Java学习第十二篇——SpringBoot+JPA提供跨域接口

    从.Net到Java学习系列目录 最近又撸了半个月的前端代码,做app离线存储,然后又花了一周去将过去的wcf项目转webapi,java又被落下了,总感觉我特么像斗地主中的癞子牌,变来变去..... ...

  7. java学习-zxing生成二维码矩阵的简单例子

    这个例子需要使用google的开源项目zxing的核心jar包 core-3.2.0.jar 可以百度搜索下载jar文件,也可使用maven添加依赖 <dependency> <gr ...

  8. salesforce零基础学习(七十九)简单排序浅谈 篇一

    我们在程序中经常需要对数据列表进行排序,有时候使用SOQL的order by 不一定能完全符合需求,需要对数据进行排序,排序可以有多种方式,不同的方式针对不同的场景.篇一只是简单的描述一下选择排序,插 ...

  9. Java学习笔记(二一)——Java 泛型

    [前面的话] 最近脸好干,掉皮,需要买点化妆品了. Java泛型好好学习一下. [定义] 一.泛型的定义主要有以下两种: 在程序编码中一些包含类型参数的类型,也就是说泛型的参数只可以代表类,不能代表个 ...

随机推荐

  1. 2301: [HAOI2011]Problem b ( 分块+莫比乌斯反演+容斥)

    2301: [HAOI2011]Problem b Time Limit: 50 Sec  Memory Limit: 256 MBSubmit: 6015  Solved: 2741[Submit] ...

  2. PAT-甲级-1003

    一.看题,https://www.patest.cn/contests/pat-a-practise/1007 其实,也是一顿暴力,但是最后一个测试点会运行超时,最开始,计算一段区间的值的总和的时候, ...

  3. Mysql修改已有数据的字符集

    Mysql修改已有数据的字符集 问题 在生产环境中跑了很久,发现MysqlClient连接的字符集是默认的latin1,我们一直以为都是utf8,造成这样的误解,是因为在内网环境中,我们是源码编译的M ...

  4. Android 开发笔记___DatePicker__日期选择器

    虽然EditText提供了inputTtype="date",但用户往往不太喜欢自己输入时间. Android为这个提供了DatePicker,但有很多缺点,不是弹窗模式,而是直接 ...

  5. 性能优化之-------少用iframe

     1.DOM开销高 使用iframe的开销是很高的,在主页面中加载同等数量的div和iframe(标签内容都是空),iframe的耗时会比div的高1~2个数量级. 2.阻塞onload事件 在典型方 ...

  6. shiro实现无状态的会话,带源码分析

    转载请在页首明显处注明作者与出处 朱小杰      http://www.cnblogs.com/zhuxiaojie/p/7809767.html 一:说明 在网上都找不到相关的信息,还是翻了大半天 ...

  7. TOMCAT启动到一半停止如何解决

    当你的项目过大的时候,往往会导致你的TOMCAT启动时间过长,启动失败,遇到该情况可以试一下下面两招: TOmcat启动到一半的时候停止了,以下原因: 1.  tomcat启动时间超过了设置时间: 解 ...

  8. mkdir--命令

    mkdir命令 mkdir:make directory(ies)的缩写,用来创建目录 1.语法 mkdir [OPTION]... DIRECTORY 注释:option是选择,可选,directo ...

  9. python模块导入的方法与区别

    import ..   #导入整个模块 from .. import .. #导入模块中的类.函数或者变量 from .. import *  #导入模块中的所有公开成员 from .. import ...

  10. Magicodes.Admin.Core开源框架总体介绍

    框架说明 Magicodes.Admin.Core框架在ABP以及ASP.NET ZERO的基础上进行了封装和完善,目前基于.NET Core 2.0+(Framework版本),由于部分组件在.NE ...