iis服务器助手广告广告
返回顶部
首页 > 资讯 > 前端开发 > node.js >常见的初级排序算法有哪些
  • 149
分享到

常见的初级排序算法有哪些

2024-04-02 19:04:59 149人浏览 泡泡鱼
摘要

本篇内容主要讲解“常见的初级排序算法有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“常见的初级排序算法有哪些”吧!前言相信所有的程序员刚开始接触到的算法都会

本篇内容主要讲解“常见的初级排序算法有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“常见的初级排序算法有哪些”吧!

前言

相信所有的程序员刚开始接触到的算法都会是排序算法,因为排序在对数据处理和计算有这重要的地位,排序算法往往是其他算法的基础;本文我们就先从初级排序算法开始学习算法。

排序算法的模板

在开始之前我们先定义一个排序算法通用的模板,在后面的排序算法都会实现这个模板

public interface SortTemplate {      void sort(Comparable[] array);      default void print(Comparable[] array) {         for (Comparable a : array) {             System.out.print(a + " ");         }     }      default boolean less(Comparable a, Comparable b) {         return a.compareTo(b) < 0;     }      default void exch(Comparable[] array, int i, int j) {         Comparable tmp = array[i];         array[i] = array[j];         array[j] = tmp;     }      }
  • Comparable: 为了让我们实现的排序算法更加的通用,可以排序任意的对象,所以我们这里使用了Comparable数组

  • sort: 不同的排序算法实现的方式不一样,子类自己去实现

  • less: 定义的公用方法,如果a < b就返回true

  • exch: 定义的公用方法,交换数组中的两个对象

  • print: 打印出数据中的每个元素

选择排序

算法实现的思路:

  • 首先找到数组中的最小元素,

  • 其实将它和数组中的第一个元素进行交换,这样就排定了一个元素;

  • 再次找出剩余元素中最小的元素与数组中的第二个元素进行交换,如此反复直到所有元素都是有序的

常见的初级排序算法有哪些

代码实现:

public class SelectionSort implements SortTemplate {      @Override     public void sort(Comparable[] array) {         int length = array.length;         for (int i = 0; i < length; i++) {             int min = i;             for (int j = i + 1; j < length; j++) {                 if (less(array[j], array[min])) {                     min = j;                 }             }             exch(array, i, min);         }     }  }

假如输入的数组是有序的,我们会发现选择排序运行的时候和未排序的时间一样长!

对于N个元素的数组,使用「选择排序的时间复杂度是O(n2)」

选择排序的是「数据移动最少」的,交换的次数与数组的大小是线性关系,N个元素的数组需要N次交换

冒泡排序

算法实现的思路:

比较相邻的两个元素,如果前一个比后一个大,那么就交换两个元素的位置

对每一组相邻的元素执行同样的操作,直到最后一个元素,操作完成之后就可以排定一个最大的元素

如此往复,直到数组中所有的元素都有序

常见的初级排序算法有哪些

代码实现:

public class BubbleSort implements SortTemplate {      @Override     public void sort(Comparable[] array) {         int length = array.length - 1;         for (int i = 0; i < length; i++) {             for (int j = 0; j < length - i; j++) {                 if (less(array[j + 1], array[j])) {                     exch(array, j, j + 1);                 }             }         }     }  }

对于N个元素的数组,使用「冒泡排序的时间复杂度是O(n2)」

插入排序

想象我们在玩扑克牌时,整理扑克牌都是把每一张插入到左边已经排好序的牌中适当的位置。插入排序的思路类似

算法实现的思路:

  • 初始默认第一个元素就是有序的,当前索引的位置从0开始

  • 先后移动当前索引的位置,当前索引位置左边的元素是有序的,从后往前开始扫码与当前索引位置元素进行比较

  • 当确定当前索引位置上的元素在左边有序适合的位置之后,插入到该位置上

  • 如果当确定当前索引位置上的元素大于了已排序的最后一个元素,那么当前索引位置直接往后移动

  • 如此反复,直到所有元素有序

常见的初级排序算法有哪些

代码实现:

public class InsertionSort implements SortTemplate {      @Override     public void sort(Comparable[] array) {         int length = array.length;         for (int i = 1; i < length; i++) {             for (int j = i; j > 0 && less(array[j], array[j - 1]); j--) {                 exch(array, j, j - 1);             }         }     }  }

从代码的实现我们可以看出,当遇到了当前索引的元素大于了左边有序数组的最后一个元素时,内层循环就直接结束了,所以所我们排序的数组中存在着部分有序,那么插入排序算法会很快。

考虑最糟糕的情况,如果输入数组是一个倒置的,那么插入排序的效率和选择排序一样,「时间复杂度是O(n2)」

希尔排序

对于大规模的乱序数组插入排序很慢,是因为它只交换相邻的元素,元素只能一点一点的从数组中移动到正确的位置;插入排序对于部分有序的数组排序是的效率很高;

希尔排序基于这两个特点对插入排序进行了改进;

算法实现的思路

  • 首先设置一个步长h用来分隔出子数组

  • 用插入排序将h个子数组独立排序

  • 减小h步长继续排序子数组,直到h步长为1

  • 当步长为1时就成了普通的插入排序,这样数组一定是有序的

希尔排序高效的原因,在排序之初,各个子数组都很短,子数组排序之后都是部分有序的,这两种情况都很适合插入排序。

常见的初级排序算法有哪些

代码实现:

public class shellSort implements SortTemplate {      @Override     public void sort(Comparable[] array) {         int gap = 1;         int length = array.length;          while (gap < length / 3) {             gap = 3 * gap + 1;         }          while (gap >= 1) {             for (int i = gap; i < length; i++) {                 for (int j = i; j >= gap && less(array[j], array[j - gap]); j -= gap) {                     exch(array, j, j - gap);                 }             }             gap = gap / 3;         }     }  }

到此,相信大家对“常见的初级排序算法有哪些”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

--结束END--

本文标题: 常见的初级排序算法有哪些

本文链接: https://www.lsjlt.com/news/83529.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 常见的初级排序算法有哪些
    本篇内容主要讲解“常见的初级排序算法有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“常见的初级排序算法有哪些”吧!前言相信所有的程序员刚开始接触到的算法都会...
    99+
    2022-10-19
  • 常见的php排序算法有哪些
    常见的PHP排序算法有以下几种:1. 冒泡排序(Bubble Sort):依次比较相邻的两个元素,将较大的元素向后移动,直到最后一个...
    99+
    2023-08-25
    php
  • 新手初学Java常见排序算法
    目录1、冒泡排序2、选择排序3、简单插入排序4、希尔排序5、归并排序6、快速排序总结1、冒泡排序 排序原理:相邻两个元素比较,如果前者比后者大,则交换两个元素。每执行一次,都会确定一...
    99+
    2022-11-12
  • Java数据结构常见排序算法有哪些
    今天小编给大家分享一下Java数据结构常见排序算法有哪些的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。1、 认识排序在学校中...
    99+
    2023-07-05
  • c++常用的排序算法有哪些
    小编给大家分享一下c++常用的排序算法有哪些,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!c++常用的排序算法//选择排序法SelectionSort(int a...
    99+
    2023-06-03
  • 常用的JS排序算法有哪些
    这篇文章给大家分享的是有关常用的JS排序算法有哪些的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。1.冒泡排序var bubbleSort = fun...
    99+
    2022-10-19
  • JavaScript中常用的排序算法有哪些
    这篇文章主要介绍JavaScript中常用的排序算法有哪些,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!一、冒泡排序冒泡排序是我们在编程算法中,算是比较常用的排序算法之一,在学习阶段...
    99+
    2022-10-19
  • 有哪些排序算法
    有哪些排序算法?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。1.插入排序—直接插入排序(Straight Insertion Sort)基本思想:将一个记录插入...
    99+
    2023-06-15
  • java的排序算法有哪些
    这篇文章主要介绍“java的排序算法有哪些”,在日常操作中,相信很多人在java的排序算法有哪些问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”java的排序算法有哪些”的疑惑有所帮助!接下来,请跟着小编一起来...
    99+
    2023-07-02
  • 浅谈Java常见的排序算法
    目录一、直接插入排序二、希尔排序三、冒泡排序四、快速排序五、选择排序(Selection Sort)六、堆排序七、归并排序一、直接插入排序 基本思想: 将一个记录插入到已排序的有序表...
    99+
    2022-11-12
  • 优化常见的java排序算法
    目录冒泡排序原始的写法优化一优化二选择排序方法一方法二堆排序建大堆来实现堆排建小堆来实现堆排插入排序实现优化一优化二归并排序递归实现归并排序优化来看O(n)的排序当然除了基于比较的排...
    99+
    2022-11-12
  • C#排序算法有哪些
    C#排序算法有哪些,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。C#排序算法一、冒泡排序(Bubble)using System;   ...
    99+
    2023-06-17
  • php排序算法有哪些
    php中常见的排序算法有冒泡排序、选择排序、插入排序、归并排序、快速排序几种冒泡排序算法冒泡排序算法是一种简单直观的排序算法,其原理是重复地走访需要排序的元素列表,依次比较两个相邻的元素,如果顺序错误就交换它们的位置,重复地进行直到没有相邻...
    99+
    2022-10-25
  • python排序算法有哪些
    python中常见的排序算法有以下几种冒泡排序算法冒泡排序算法是一种简单直观的排序算法,其原理是重复地走访需要排序的元素列表,依次比较两个相邻的元素,如果顺序错误就交换它们的位置,重复地进行直到没有相邻的元素需要交换,则元素列表排序完成。选...
    99+
    2022-10-04
  • Python中的排序算法有哪些?
    Python中常用的排序算法有冒泡排序、插入排序、选择排序、快速排序、归并排序和堆排序等。下面将分别介绍这些排序算法的原理,并给出相应的代码示例。冒泡排序:冒泡排序是一种简单直观的排序算法。它重复地遍历要排序的列表,比较相邻两个元素大小,并...
    99+
    2023-10-22
    算法 Python 排序算法 排序算法的关键词:
  • 介绍java中的常见排序算法
    Java中的排序算法主要包括以下几种: 冒泡排序(Bubble Sort)选择排序(Selection Sort)插入排序(Insertion Sort)快速排序(Quick Sort)归并排序(Merge Sort)堆排序(Heap So...
    99+
    2023-10-26
    算法 排序算法 数据结构 java 笔记 学习
  • C#中有哪些排序算法
    这期内容当中小编将会给大家带来有关C#中有哪些排序算法,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。C#排序算法之冒泡排序   一下是C#开发出冒泡排序算法。希望能为C#语言的学习者带...
    99+
    2023-06-17
  • JavaScript中有哪些排序算法
    这期内容当中小编将会给大家带来有关JavaScript中有哪些排序算法,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。说明&middot;  每个浏览器测...
    99+
    2022-10-19
  • 盘点几种常见的java排序算法
    目录1.插入排序2.分治排序法,快速排序法3.冒泡排序 low版4.冒泡排序 bigger版5.选择排序6. 归并排序8. 堆排序9. 其他排序10. 比较总结1.插入排序 这个打...
    99+
    2022-11-12
  • PHP常见的几种排序算法介绍
    这篇文章主要介绍“PHP常见的几种排序算法介绍”,在日常操作中,相信很多人在PHP常见的几种排序算法介绍问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”PHP常见的几种排序算法...
    99+
    2022-10-19
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作