`

【转载】各种数组排序方法总结

    博客分类:
  • Java
阅读更多

import java.lang.Math;
import java.util.Random;

/**
 * 排序
 *
 * @author javajack  
 */
public class OrderTest {

    public static void main(String args[]) {
        OrderTest.ExecOrder(2);
    }

    /**
     * 交换值,交换数组的两个值
     * @param array
     * @param i
     * @param j
     */
    private static void swap(int[] array,int i, int j)
    {
        int tmp = array[i];
        array[i] = array[j];
        array[j] = tmp;
    }    
    
    /**
     *
     * @param method
     *            1为升序,2为降序
     */
    public static void ExecOrder(int method) {
        int[] array = null;
        array = initArray(10, 210, 10);
        
         //int[] orderarray = bubbleOrder(array,method);
        int[] orderarray = doubleBubbleOrder(array,method);
        //int[] orderarray = insertOrder(array, method);
        //int [] orderarray = quickOrder(array,method);
        //int[] orderarray = selectOrder(array, method);
        for (int i = 0; i < orderarray.length; i++) {
            System.out.println(orderarray[i]);
        }
    }

    /**
     * 取随机数据,初始化一个数组
     *
     * @param min
     *            随机数的最小值
     * @param max
     *            最大值
     * @param size
     *            取得随机数的数量
     * @return
     */
    public static int[] initArray(int min, int max, int size) {
        int[] init = new int[size];

        for (int i = 0; i < size; i++) {
            Random ra = new Random();
            init[i] = min + (int) (Math.random() * (max - min + 1));
            System.out.println(i + "-------" + init[i]);
        }
        return init;
    }

    /**
     * 交换排序方法
     * 原理:依次交换值
     * @param array
     * @return
     */
    public static int[] convertOrder(int[] array, int method) {
        for (int i = 0; i < array.length; i++) {
            for (int j = i + 1; j < array.length; j++)
            {
                if (method==2)
                {
                    if (array[i] < array[j])
                        swap(array,i,j);
                }else if (method == 1) {
                    if (array[i] > array[j])
                        swap(array,i,j);
                }
            }
        }
        return array;
    }

    /**冒泡排序方法
     * 原理:从最后一个开始将小的或大的逐渐冒出
     * @param array
     * @param method
     * @return
     */
    public static int[] bubbleOrder(int[] array,int method)
    {
        for(int i=0;i<array.length;i++)
        {
            for (int j=array.length -1 ;j>i;j--)
            {
                if (method==2)
                {
                    if (array[i] < array[j])
                        swap(array,i,j);
                }else if (method==1)
                    if (array[i] > array[j])
                        swap(array,i,j);
            }
        }
        return array;
    }
    
    /**
     * 双向冒泡排序
     * 原理:类似于冒泡排序,只不过是双向的
     * @param array
     * @param method
     * @return
     */
    public static int[] doubleBubbleOrder(int[] array,int method)
    {
        int left = 0;
        int right = array.length -1 ;
        while (left < right)
        {
            for(int i=left;i<=right;i++)
            {
                if (method==1)
                {
                    if (array[left] > array[i])
                        swap(array,left,i);
                }else
                {
                    if (array[left] < array[i])
                        swap(array,left,i);
                }
            }
            
            for (int i=left+1;i<=right;i++)
            {
                if (method==1)
                {
                    if (array[right] < array[i])
                        swap(array,right,i);
                }else
                {
                    if (array[right] > array[i])
                        swap(array,right,i);
                    
                }
            }
            left++;
            right--;
        }
        return array;
    }
    
    /**
     * 快速排序方法,运用到递归
     * 排序原理:随机找到一个值,然后以此值大小进行分为两个数组,大的放左边,小的放右边,
     * 然后再对左右两侧的数据依次排序根据
     * @param array
     * @param method
     * @return
     */
    public static int[] quickOrder(int[] array, int method)
    {
        quickDeal(array,0,array.length - 1,method);
        return array;
    }

    /**
     *
     * @param array
     * @param begin
     *            开始位置
     * @param end
     *            结束位置
     */
    private static void quickDeal(int[] array, int begin, int end,int method) {
        if (end > begin) {
            int pos = begin + (int) (Math.random() * (end - begin + 1)); // 计算分隔位置
            int posvalue = array[pos]; // 取得分隔位置的值
            swap(array,pos,end); //将posvalue放到最end的位置
            pos=begin; //初始化pos
            for (int i=begin; i < end; i++) {
                if (method==1)
                {    
                    if (array[i] < posvalue) { //当小于posvalue时,将此值移动到pos位置,也就是向前移动
                        swap(array,pos,i);
                        pos++; //移动后pos增1
                    }
                }else if(method == 2)
                {
                    if (array[i] > posvalue) { //当小于posvalue时,将此值移动到pos位置,也就是向前移动
                        swap(array,pos,i);
                        pos++; //移动后pos增1
                    }
                }
            }
            swap(array,pos,end); //end位置的值前移
            quickDeal(array,begin,pos -1,method);
            quickDeal(array,pos+1,end,method);
        }

    }

    /**
     * 插入排序方法
     * 排序原理:抽出一个数,做为排序基序列,然后依次抽出其它数与,与此序列中的数进行比较,放入合适的位置
     * @param array
     * @param method
     * @return
     */
    public static int[] insertOrder(int[] array, int method) {

        for (int i = 1; i < array.length; i++) {
            if (method == 1) {
                if (array[i - 1] > array[i]) {
                    int tmp = array[i]; //
                    int j = i - 1;
                    do {
                        array[j + 1] = array[j];
                        j--;
                    } while (j >= 0 && tmp < array[j]); //当j>=0并且 当前值大于数据中j位置的值时移动
                    array[j + 1] = tmp; //插入排序值
                }
            } else if (method == 2) {
                if (array[i - 1] < array[i]) {
                    int tmp = array[i];
                    int j = i - 1;
                    do {
                        array[j + 1] = array[j];
                        j--;
                    } while (j >= 0 && tmp > array[j]);
                    array[j + 1] = tmp;
                }
            }
        }
        return array;
    }

    /**
     * 选择排序方法
     * 排序原理:每次选择一个最大的或最小的数放到已排序序列中
     * @param array
     * @param method
     * @return
     */
    public static int[] selectOrder(int[] array,int method)
    {
        for (int i=0;i<array.length - 1;i++)
        {
            int tmp = array[i];
            int pos = i+1; //记录大值或小值的位置 
            for (int j=i+1;j<array.length;j++)
            {
                if (method==1)
                {
                    if (array[j]<tmp)
                    {
                        tmp = array[j];
                        pos= j ;//记录大值或小值的位置
                    }
                }else if (method==2)
                {
                    if (array[j]>tmp)
                    {
                        tmp = array[j];
                        pos= j ;//记录大值或小值的位置
                    }
                }
            }
            if (tmp != array[i])
                swap(array,i,pos); //不相同时交换
        }
        return array;
    }

    
}

分享到:
评论

相关推荐

    排序算法总结(转载)

    本文将对几种常见的排序算法进行总结,包括冒泡排序、选择排序、插入排序、希尔排序、归并排序、快速排序、堆排序、拓扑排序、锦标赛排序以及基数排序。 **冒泡排序**: 冒泡排序是最基础的排序算法之一,通过不断...

    剑指Offer – 面试题51. 数组中的逆序对(归并排序,求逆序对)

    1. 题目 在数组中的两个数字,如果前面一个数字大于后面的数字,则这两个数字组成一个逆序对。输入一个数组,求出这个数组中的逆序对的... 计算右侧小于当前元素的个数(二叉查找树&二分查找&归并排序逆序数总结) 方法

    [转载]nlogn的最长子序列算法.rar_最长 排序_最长子序列

    总结起来,求解最长子序列问题的一种高效方法是结合排序和动态规划的思路,通过O(nlogn)的时间复杂度找到最长的非降序子序列。这种方法在实际应用中,如数据挖掘、算法竞赛等领域有着广泛的应用。

    c#语言版数据结构(转载)

    - **线性表**:包括链表、数组等数据结构的实现和操作方法。 - **栈和队列**:介绍这两种特殊的数据结构以及它们的应用场景。 - **串和数组**:讲解字符串处理和数组操作的技术细节。 - **树型结构**:涵盖二叉树、...

    背包九讲1

    - 完全背包问题与普通背包问题的区别在于,每种物品可以有无限个,优化方法包括将物品按单位重量的价值排序,先考虑价值高的物品。 - 一个简单有效的优化是对物品进行排序,使得在有限的空间内,价值能最大化。 -...

    转载:再谈“可输入的下拉框”,完全支持中文输入

    6. 数据结构与数组操作:存储下拉选项的数据,可能需要进行搜索、排序等操作。 7. 响应式设计:确保组件在不同设备和屏幕尺寸上的表现良好。 8. ARIA(Accessible Rich Internet Applications):对于无障碍性,确保...

    pocketc 教程 转载 小羊编写

    - **数组**:只支持一维数组,可以通过其他方式模拟多维数组。 ##### 2.5 指针 - **定义**:使用`pointer`关键字定义指针变量。 - **函数引用**:可以使用指针来引用函数,并通过指针调用函数。 #### 三、控制结构...

    c++ 面试题 总结

    各种内存管理都有它自己的方法来计算出程序片断在主存中的物理地址,其实都很相似。 这只是一个大概而已,不足以说明内存管理的皮毛。无论哪一本操作系统书上都有详细的讲解 -----------------------------------...

    vue列表数据发生变化指令没有更新问题及解决方法

    在上述例子中,`:key='index'`可能导致问题,因为当过滤或排序列表时,尽管数据发生了变化,但索引可能保持不变,导致Vue认为元素没有变化,从而不触发指令的更新。 **问题分析:** 在Vue的`v-for`循环中,`:key`...

Global site tag (gtag.js) - Google Analytics