java几种基本排序

如题所述

/**
     * å†’泡排序
     * æ¯”较相邻的元素。如果第一个比第二个大,就交换他们两个。  
     * å¯¹æ¯ä¸€å¯¹ç›¸é‚»å…ƒç´ ä½œåŒæ ·çš„工作,从开始第一对到结尾的最后一对。在这一点,最后的元素应该会是最大的数。  
     * é’ˆå¯¹æ‰€æœ‰çš„元素重复以上的步骤,除了最后一个。
     * æŒç»­æ¯æ¬¡å¯¹è¶Šæ¥è¶Šå°‘的元素重复上面的步骤,直到没有任何一对数字需要比较。 
     * @param numbers éœ€è¦æŽ’序的整型数组
     */
    public static void bubbleSort(int[] numbers)
    {
        int temp = 0;
        int size = numbers.length;
        for(int i = 0 ; i < size-1; i ++)
        {
        for(int j = 0 ;j < size-1-i ; j++)
        {
            if(numbers[j] > numbers[j+1])  //交换两数位置
            {
            temp = numbers[j];
            numbers[j] = numbers[j+1];
            numbers[j+1] = temp;
            }
        }
        }
    }
快速排序的基本思想:
         é€šè¿‡ä¸€è¶ŸæŽ’序将待排序记录分割成独立的两部分,其中一部分记录的关键字均比另一部分关键字小,则分别对这两部分继续进行排序,直到整个序列有序。
/**
     * æŸ¥æ‰¾å‡ºä¸­è½´ï¼ˆé»˜è®¤æ˜¯æœ€ä½Žä½low)的在numbers数组排序后所在位置
     * 
     * @param numbers å¸¦æŸ¥æ‰¾æ•°ç»„
     * @param low   å¼€å§‹ä½ç½®
     * @param high  ç»“束位置
     * @return  ä¸­è½´æ‰€åœ¨ä½ç½®
     */
    public static int getMiddle(int[] numbers, int low,int high)
    {
        int temp = numbers[low]; //数组的第一个作为中轴
        while(low < high)
        {
        while(low < high && numbers[high] > temp)
        {
            high--;
        }
        numbers[low] = numbers[high];//比中轴小的记录移到低端
        while(low < high && numbers[low] < temp)
        {
            low++;
        }
        numbers[high] = numbers[low] ; //比中轴大的记录移到高端
        }
        numbers[low] = temp ; //中轴记录到尾
        return low ; // è¿”回中轴的位置
    }
    
    é€’归形式的分治排序算法:
    /**
     * 
     * @param numbers å¸¦æŽ’序数组
     * @param low  å¼€å§‹ä½ç½®
     * @param high ç»“束位置
     */
    public static void quickSort(int[] numbers,int low,int high)
    {
        if(low < high)
        {
        ã€€ã€€int middle = getMiddle(numbers,low,high); //将numbers数组进行一分为二
        ã€€ã€€quickSort(numbers, low, middle-1);   //对低字段表进行递归排序
        ã€€ã€€quickSort(numbers, middle+1, high); //对高字段表进行递归排序
        }
    
    }
温馨提示:答案为网友推荐,仅供参考