Java实现七种排序-选择 插入 冒泡 归并 快排 希尔 堆排序

这篇博客详细介绍了Java实现的选择排序、插入排序、冒泡排序、归并排序、快速排序、希尔排序和堆排序的算法思想、时间复杂度、稳定性及代码实现。通过对这些排序算法的理解和实践,有助于提升编程能力,尤其在面试和解决问题时能快速应用。
摘要由CSDN通过智能技术生成

目录

一、前言

二、七种经典排序

1.直接选择排序

2.直接插入排序

3.冒泡排序

4.归并排序

5.快速排序

6.希尔排序

7.堆排序

三、总结


一、前言

关于各种排序问题,是笔试面试中的经典问题,很多同学表示看的时候都懂了,用的时候全混了(没错就是我==)。所以为了方便复习(预习),下面整理了各种算法思想以及复杂度,当然还有代码实现。

二、七种经典排序

1.直接选择排序

简单来说,选择排序就是每次找未排序数组中的最小(或者最大)的记录并固定其位置

 * 思想:    ①对于给定的一组记录,经过第一轮比较后得到最小的记录,然后将该记录与第一个记录的位置进行交换;
                  ②接着对不包括第一个记录之外的其他记录进行第二轮比较,得到最小的记录并与第二个记录进行位置交换;  
                  ③重复该过程  直到全部排序

 *时间复杂度:最好 最坏 平均时间均为O(n^2)
 *辅助空间O(1)
 *稳定性不稳定

Java代码实现直接选择排序

public class SelectSort {

    public static void selectSort(int[] a) {
        int temp = 0; //用来放每趟中的最小值
        int index = 0; //用来放上面最小值temp对应的数组下标
        int len = a.length; //数组长度

        for(int i=0;i<len;i++) {//某一趟
            temp = a[i];
            index = i;
            for(int j=i+1;j<len;j++) { //在该趟找出未排序部分的最小值放temp中,从前往后依次比较
                if(a[j] < temp) {
                    temp = a[j];
                    index = j;
                }
            }
            if(index != i) { //找到最小值位置且不是a[i],就进行交换
                a[index] = a[i];
                a[i] = temp; //交换第i个位置数据
            }
        }
    }

    public static void main(String[] args) {
        int[] array = {5,4,3,7,6,8,10,1};
        System.out.print("原数组:");
        for(int ai : array) {
            System.out.print(ai+" ");
        }
        System.out.println();

        selectSort(array);

        System.out.print("选择排序后:");
        for(int ai : array) {
            System.out.print(ai+" ");
        }
    }
}

2.直接插入排序

 * 算法思想:  初始时假设第一个记录自成一个有序序列,其余记录均为无序序列。
 *           接着从第二个记录开始,按照记录的大小依次将当前处理的记录插入到其之前的有序序列中,
 *           直到最后一个记录插入到有序序列中为止

 * 时间复杂度:最好时间:O(n);最坏 平均:O(n^2)
 * 辅助空间O(1)     
 * 稳定性稳定的!!!

Java代码实现插入排序:

public class InsertSort {

	public static void insertSort(int[] a) {
		int len = a.length; //数组的长度
		if(a != null) {
			for
  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值