面试时常常考察的java排序算法--选择排序、冒泡排序、插入排序

简介: 面试时常常考察的java排序算法--选择排序、冒泡排序、插入排序

注:本文是从java语言角度对三种排序算法进行分析比较。

一、选择排序

核心思想:

依次拿当前元素和其后面的元素比较大小,满足条件就互换值

public static int[] shunxu(int[] arr){
  int len = arr.length;
  int temp = 0;
  for (int i = 0; i < len-1; i++) {
    for (int j = i+1; j < len; j++) {
      if(arr[i] > arr[j]){
        temp = arr[i];
        arr[i] = arr[j];
        arr[j] = temp;
      }
    }
  }
  return arr;
}

解读:

arr[i]是当前元素,范围是[0,arr.length-1)

arr[j]是当前元素后面的元素,范围是[i+1,arr.length)

时间复杂度:

最好的情况是所有数字都是有序的,对于n位的数组,时间复杂度为O(n);


最坏的情况是把顺序的排列变成逆序,或者把逆序的数列变成顺序。在这种情况下,每一次比较都需要进行交换运算。对于n位的数组,则有比较次数为 (n-1) + (n-2) + ... + 1 = n * (n - 1) / 2,这就得到了最大的比较次数。所以时间复杂度为o(n(n-1)/2)

二、冒泡排序

核心思想:

依次拿相邻的元素做比较,满足条件就互换值。

每轮比较找到一个最值(最大或者最小),把其放到末尾

public static int[] maopao(int[] arr){
  int len = arr.length;
  int temp = 0;
  for (int i = 0; i < len-1; i++) {
    for (int j = 0; j < len-1-i; j++) {
      if(arr[j] > arr[j+1]){
        temp = arr[j];
        arr[j] = arr[j+1];
        arr[j+1] = temp;
      }
    }
  }
  return arr;
}

解读:

外层for循环表示比较轮数,范围是[0,arr.length-1),总共比较了length-1轮


内层for循环表示第 i 轮比较的次数,范围是[0,arr.length-1-i)


每一轮都会产生一个最值(最大值或最小值),则下一轮就少比较一次


外层for循环控制比较的总轮数,该循环是以内层for循环的变量 j 作为数组的下标进行比较时间复杂度:

最好的情况同选择排序,即所有数字都是有序的,对于n位的数组,时间复杂度为O(n);


最坏的情况同顺序排序,是把顺序的排列变成逆序,或者把逆序的数列变成顺序。在这种情况下,每一次比较都需要进行交换运算。对于n位的数组,则有比较次数为 (n-1) + (n-2) + ... + 1 = n * (n - 1) / 2,这就得到了最大的比较次数。所有时间复杂度为o(n(n-1)/2)

三、插入排序

核心思想:

假设前面的数字是有序的,依次拿当前元素与前面元素做比较,满足条件就互换值

public static int[] charu(int[] arr){
  int len = arr.length;
  int temp = 0;
  for (int i = 1; i < len; i++) {
    for (int j = i; j > 0; j--) {
      if(arr[j] > arr[j-1]){
        temp = arr[j];
        arr[j] = arr[j-1];
        arr[j-1] = temp;
      }else{
        break;
      }
    }
  }
  return arr;
}

解读:

外层for循环控制轮数,范围是[1,arr.length)

从第2个数字开始,与前面的数字比较,满足条件就互换值,否则就放到当前位置(代码中有break)

时间复杂度:

最好的情况跟上面的相同,是所有数字都是有序的,对于n位的数组,时间复杂度为O(n);


最坏的情况跟上面的相同,是把顺序的排列变成逆序,或者把逆序的数列变成顺序。在这种情况下,每一次比较都需要进行交换运算。对于n位的数组,则有比较次数为 (n-1) + (n-2) + ... + 1 = n * (n - 1) / 2,这就得到了最大的比较次数。所有时间复杂度为o(n(n-1)/2)

三种排序算法对比

根据时间复杂度来比较,三种排序算法的最好和最坏的值都是相同的。所以,我们无法从时间复杂度上面来对比他们。


我们可以从代码上面分析,由于插入排序代码里有一个break,以至于不满足条件的时候,直接中断内层for循环的执行。所以,相对于其它算法,它的比较次数相应的会少很多,所以效率会更快。


综合考虑的情况下,插入排序>=冒泡排序>=选择排序

与其它排序对比:

相关文章
|
6月前
|
算法 Java
50道java集合面试题
50道 java 集合面试题
|
8月前
|
缓存 Java API
Java 面试实操指南与最新技术结合的实战攻略
本指南涵盖Java 17+新特性、Spring Boot 3微服务、响应式编程、容器化部署与数据缓存实操,结合代码案例解析高频面试技术点,助你掌握最新Java技术栈,提升实战能力,轻松应对Java中高级岗位面试。
580 0
|
8月前
|
Java 数据库连接 数据库
Java 相关知识点总结含基础语法进阶技巧及面试重点知识
本文全面总结了Java核心知识点,涵盖基础语法、面向对象、集合框架、并发编程、网络编程及主流框架如Spring生态、MyBatis等,结合JVM原理与性能优化技巧,并通过一个学生信息管理系统的实战案例,帮助你快速掌握Java开发技能,适合Java学习与面试准备。
369 2
Java 相关知识点总结含基础语法进阶技巧及面试重点知识
|
6月前
|
算法 Java
50道java基础面试题
50道java基础面试题
|
8月前
|
搜索推荐 算法 Go
Go语言数组排序(冒泡排序法)—— 用最直观的方式掌握排序算法
本案例介绍使用冒泡排序对整数数组进行升序排序的实现方法,涵盖输入处理、错误检查与排序逻辑。通过代码演示和算法解析,帮助理解排序原理及Go语言切片操作,为学习更复杂排序算法打下基础。
|
8月前
|
缓存 Java 关系型数据库
Java 面试经验总结与最新 BAT 面试资料整理含核心考点的 Java 面试经验及最新 BAT 面试资料
本文汇总了Java面试经验与BAT等大厂常见面试考点,涵盖心态准备、简历优化、面试技巧及Java基础、多线程、JVM、数据库、框架等核心技术点,并附实际代码示例,助力高效备战Java面试。
315 0
|
8月前
|
缓存 Cloud Native Java
Java 面试微服务架构与云原生技术实操内容及核心考点梳理 Java 面试
本内容涵盖Java面试核心技术实操,包括微服务架构(Spring Cloud Alibaba)、响应式编程(WebFlux)、容器化(Docker+K8s)、函数式编程、多级缓存、分库分表、链路追踪(Skywalking)等大厂高频考点,助你系统提升面试能力。
817 0
|
8月前
|
搜索推荐
冒泡排序与其它排序算法比较
本内容比较了冒泡排序、选择排序和插入排序的特性。三者时间复杂度均为O(n²),但交换次数和稳定性不同。冒泡排序稳定,交换次数多,可优化至O(n);选择排序不稳定,交换次数少;插入排序交换次数最少,且二者均为稳定排序。对于有序数组,冒泡和插入可优化提升效率。
160 0
|
存储 算法 Java
大厂面试高频:什么是自旋锁?Java 实现自旋锁的原理?
本文详解自旋锁的概念、优缺点、使用场景及Java实现。关注【mikechen的互联网架构】,10年+BAT架构经验倾囊相授。
大厂面试高频:什么是自旋锁?Java 实现自旋锁的原理?