快速突破面试算法之排序篇

一、前言:什么是排序算法

老祖宗说得好:没有规矩不成方圆!

所以说排序这个事,砸门丢不得,也不能丢!因为面试被手撕八大排序的可能比较大!!!

二、八大排序

既然有八种,存在着了,我们吃瓜群众肯定喜欢看那个最NB,那个最菜!我们之后才能用那个更方便!

①直接插入排序

应用场景:

把新的数插入到已经排好的数组中。

基本思想:

将第一个数和第二个数排序,然后构成一个有序序列 将第三个数插入进去,构成一个新的有序序列。 对第四个数、第五个数……直到最后一个数,重复第二步。

算法描述

  1. 首先设定插入次数,即循环次数,for(int i=1;i<length;i++),1个数的那次不用插入。
  2. 设定插入数和得到已经排好序列的最后一个数的位数。insertNum和j=i-1。
  3. 从最后一个数开始向前循环,如果插入数小于当前数,就将当前数向后移动一位。
  4. 将当前数放置到空着的位置,即j+1。

代码实现:

public void insertSort(int[] a){
        int length=a.length;//数组长度,将这个提取出来是为了提高速度。
        int insertNum;//要插入的数
        for(int i=1;i<length;i++){//插入的次数
            insertNum=a[i];//要插入的数
            int j=i-1;//已经排序好的序列元素个数
            while(j>=0&&a[j]>insertNum){//序列从后到前循环,将大于insertNum的数向后移动一格
                a[j+1]=a[j];//元素移动一格
                j--;
            }
            a[j+1]=insertNum;//将需要插入的数放在要插入的位置。
        }
    }

②希尔排序③简单选择排序④堆排⑤冒泡排序(经常手撕)⑥快速排序(经常手撕)⑦归并排序⑧基数排序

这些动图和思路请参考这篇文章,写的超级好!!图文并茂很棒!

三、一切理论都源于实践,多刷题领悟其中精髓才能真正掌握!

四、排序相关的面试高频题目录

1.数组中第的K个最大元素(力扣 215) 博主的笔记思路及代码讲解:

2.前K个高频元素(力扣 347) 博主的笔记思路及代码讲解:

3.根据字符出现的频率排序(力扣451) 博主的笔记思路及代码讲解:

4.国旗问题:颜色分类(力扣75) 博主的笔记思路及代码讲解:

五、各种类型的高频面试题汇总:

六、如有疑问可加QQ群讨论:725936761     博主免费答疑
欢迎大家一起讨论进步。后续遇到相似的题会继续更新!

群里已有字节、滴滴大佬,可帮忙内推!也欢迎其他大厂的工作人士进群!帮忙内推~

 

B站视频讲解如何三个月学习JAVA拿到实习Offer:

经验分享 程序员 微信小程序 职场和发展