`
Dream.V
  • 浏览: 32797 次
社区版块
存档分类
最新评论

关于java的几种排序方式。。

 
阅读更多

最主要的是冒泡排序、选择排序、插入排序以及快速排序


1、冒泡排序

冒泡排序是一个比较简单的排序方法。在待排序的数列基本有序的情况下排序速度较快。若要排序的数有n个,则需要n-1轮排序,第j轮排序中,从第一个数开始,相邻两数比较,若不符合所要求的顺序,则交换两者的位置;直到第n+1-j个数为止,第一个数与第二个数比较,第二个数与第三个数比较,......,第n-j个与第n+1-j个比较,共比较n-1次。此时第n+1-j个位置上的数已经按要求排好,所以不参加以后的比较和交换操作。例如:第一轮排序:第一个数与第二个数进行比较,若不符合要求的顺序,则交换两者的位置,否则继续进行二个数与第三个数比较......。直到完成第n-1个数与第n个数的比较。此时第n个位置上的数已经按要求排好,它不参与以后的比较和交换操作;第二轮排序:第一个数与第二个数进行比较,......直到完成第n-2个数与第n-1个数的比较;......第n-1轮排序:第一个数与第二个数进行比较,若符合所要求的顺序,则结束冒泡法排序;若不符合要求的顺序,则交换两者的位置,然后结束冒泡法排序。
共n-1轮排序处理,第j轮进行n-j次比较和至多n-j次交换。
从以上排序过程可以看出,较大的数像气泡一样向上冒,而较小的数往下沉,故称冒泡法。


 public void bubbleSort(int a[])
    {
        int n = a.length;
        for(int i=0;i<n-1;i++)
        {
            for(int j=0;j<n-i-1;j++)
            {
                 if(a[j] > a[j+1])
                 {
                     int temp = a[j];
                     a[j] = a[j + 1];
                     a[j + 1] = temp;
                 }
            }
        }
     }

2、选择排序

选择法的原理是先将第一个数与后面的每一个数依次比较,不断将将小的赋给第一个数,从而找出最小的,然后第二个数与后面的每一个数依次比较,从而找出第二小的,然后第三个数与后面的每一个数依次比较,从而找出第三小的.....直到找到最后一个数。


public void sort(int x[])
     {
         int n=x.length;
         int k,t;
         for(int i=0;i<n-1;i++)
         {
              k=i;
              for(int j=i+1;j=n;j++)
              {
                   if(x[j]>x[k])k=j;
                   if(k!=i)
                   {
                         t=x[i];
                         x[i]=x[k];
                         x[k]=t;
                    }
               }
         }
     }

3、插入排序

插入排序的原理是对数组中的第i个元素,认为它前面的i-1个已经排序好,然后将它插入到前面的i-1个元素中。插入排序对少量元素的排序较为有效.


public void sort(int obj[])
    {
        for(int j=1;j<obj.length;j++)
        {
             int key=obj[j];
             int i=j-1;
             while(i>=0&&obj[i]>key)
             {
                  obj[i+1]=obj[i];
                  i--;
             }
             obj[i+1]=key;
        }
    }

4、快速排序

快速排序是对冒泡排序的一种改进。它的基本思想是:通过一次排序将要排序的数据分割成独立的两部分,其中一部分的所有数据都比另外一部分的所有数据都要小,然后再按次方法对这两部分数据分别进行快速排序,整个排序过程可以递归进行,以此大道整个数据变成有序序列。


public void quickSort(int obj[],int low,int high)
    {
         int i=low;
         int j=high;
         int keyValue=obj[i];
         while(i<j)
         {
              int temp=0;
              while(i<j&&obj[j]>=keyValue)
              {
                   j=j-1;
               }
               temp=obj[j];
               obj[j]=obj[i];
               obj[i]=temp;
               while(i<j&&obj[i]<=keyValue)
               {
                    i=i+1;
                }
                temp=obj[j];
                obj[j]=ojb[i];
                obj[i]=temp;
         }
         obj[i]=keyValue;
         if(low<i-1)
         {
             quickSort(obj,low,i-1);
         }
         if(high>i+1)
         {
              quickSort(obj,i+1,high);
         }
     }

研究一下,还蛮有意思的。
分享到:
评论

相关推荐

    Java几种排序方法

    根据给定的信息,本文将详细介绍Java中的四种基本排序算法:冒泡排序、插入排序、快速排序和选择排序。...以上四种排序算法各有优缺点,适用场景也不同。在实际应用中,根据具体需求选择合适的排序算法是非常重要的。

    java最常见的几种排序

    java排序算法,包括冒泡、插入、快速、选择等四种最常见的排序算法

    Java实现几种常见排序方法

    ### Java 实现几种常见排序方法 #### 泡泡排序(Bubble Sort) 泡泡排序是一种简单的排序算法,它重复地遍历待排序的数列,依次比较相邻的两个元素,如果它们的顺序错误就把它们交换过来。遍历数列的工作是重复...

    用Java实现几种常见的排序算法

    根据提供的文件信息,本文将详细介绍如何使用Java语言来实现几种常见的排序算法,包括插入排序(Insert Sort)、冒泡排序(Bubble Sort)、选择排序(Selection Sort)以及希尔排序(Shell Sort)。这些排序算法在...

    Java几种常见的排序方法

    Java中几种比较常见的排序方法,像冒泡、快速排序、插入排序登。

    JAVA几种常用的排序算法

    JAVA几种常用的经典的排序算法 冒泡 选择 快速 shell 堆排序

    Java几种排序算法

    本文将详细介绍Java中常见的几种排序算法,包括冒泡排序、快速排序以及选择排序。 1. **冒泡排序**: 冒泡排序是最基础的排序算法之一,它的主要思想是通过不断比较相邻元素并交换位置,使得较大的元素逐渐“浮”到...

    java几种排序方法代码

    使用java实现的选择、冒泡、插入、快速、希尔排序以及折半查找

    java的几种排序方式.doc

    Java 的几种排序方式 Java 语言中有多种排序方式,包括插入排序、冒泡排序、选择排序、Shell 排序、快速排序、归并排序、堆排序等。在本文中,我们将对这些排序方式进行详细的介绍和分析。 一、插入排序 插入排序...

    java源码 多种排序方式

    以下是几种常见的排序算法及其详细解释: 1. 冒泡排序(Bubble Sort): 冒泡排序是最简单的排序算法之一,通过不断交换相邻两个元素的位置来达到排序的目的。其核心思想是每一轮遍历都将最大(或最小)的元素...

    Java几种常见的排序算法

    Java几种常见的排序算法

    java几种基本排序(动态演示)

    在项目中,"Sortshow"可能是一个包含所有相关代码的类或包,其中包含了用于创建GUI界面、启动线程、更新界面显示以及具体实现三种排序算法的函数。使用Java多线程可以确保排序过程的动态展示不影响主程序的运行,...

    java编写的几种排序算法

    本文将深入探讨在Java中实现的几种常见排序算法:冒泡排序、快速排序以及堆排序。 1. **冒泡排序(Bubble Sort)** 冒泡排序是最简单的排序算法之一,通过重复遍历数组,比较相邻元素并交换位置,直到没有任何一对...

    java汉字笔画排序2例子及jar包

    在给出的标题"java汉字笔画排序2例子及jar包"中,我们可以推断这是一个关于Java实现汉字笔画排序的项目,其中可能包含了两种不同的实现方式或者优化后的版本。 描述中提到,"对排序方法重新定义,减少占用,效率...

    几种常用的排序法 java程序

    这三种排序算法各有特点: - 快速排序:平均时间复杂度为O(n log n),但最坏情况下为O(n^2),适用于大多数情况。 - 堆排序:稳定的时间复杂度O(n log n),原地排序,但性能受数据分布影响。 - 归并排序:最稳定的O(n...

    java 各种排序排序.pdf

    从给定的文件信息中,我们可以提炼出关于Java中几种主要排序算法的详细知识点,包括插入排序、希尔排序、选择排序、堆排序以及交换排序。下面将深入探讨这些排序算法的特点、工作原理以及它们的稳定性与时间复杂度。...

    几种内部排序算法的Java实现

    希尔排序是插入排序的一种优化,通过设置增量 gap 将待排序序列分隔成多个子序列,每个子序列进行插入排序。随着 gap 的逐渐减小,最终达到 gap=1,即所有元素都在同一个子序列中,此时进行最后一次插入排序。希尔...

    用Java实现几种常见的排序算法.txt

    根据提供的文件信息,我们可以总结出该文档主要涉及了五种基于...以上就是关于这五种排序算法的介绍及其基于Java的实现方式。这些排序算法各有优缺点,适用于不同的场景,了解并掌握它们能够帮助开发者更好地解决问题。

    JAVA关于几种排序算法的性能比较.pdf

    这个文件"JAVA关于几种排序算法的性能比较.pdf"显然探讨了不同排序算法在Java环境下的效率对比,包括直接插入排序、直接选择排序、冒泡排序、希尔排序、快速排序和堆排序。这些排序算法各有优劣,适用于不同的场景,...

Global site tag (gtag.js) - Google Analytics