免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 998 | 回复: 0
打印 上一主题 下一主题

常用排序算法java实现 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2007-06-06 12:40 |只看该作者 |倒序浏览
经常我们会用到一些排序算法,下面是用java的实现



package jt.test;
public class SortUtil {
    /**
     * 交换数组中i和j的位置
     *
     * @param array
     * @param i
     * @param j
     */
    private static void swap(int[] array, int i, int j) {
        int tmp = array;
        array = array[j];
        array[j] = tmp;
    }
    private static boolean lt(int x, int y) {
        return x  y;
    }
    private static boolean gt(int x, int y) {
        return x > y;
    }
    /**
     * 输出数组结果
     *
     * @param array
     */
    public static void printArrays(int[] array) {
        for (int num : array) {
            System.out.print(num);
            System.out.print(' ');
        }
    }
    /**
     * 冒泡法排序
     *
     * @param array
     */
    public static void BubbleSort(int[] array) {
        int count = array.length;
        if (count == 0) {
            return;
        }
        boolean noSwap = false;
        for (int i = 1; i  count; i++) {
            noSwap = true;
            for (int j = count - 1; j >= i; j--) {
                if (lt(array[j], array[j - 1])) {
                    swap(array, j, j - 1);
                    noSwap = false;
                }
            }
            if (noSwap) {
                return;
            }
        }
    }
    /**
     * 选择法排序
     *
     * @param array
     */
    public static void SelectSort(int[] array) {
        for (int i = 0; i  array.length - 1; i++) {
            int smallest = i;
            for (int j = i + 1; j  array.length; j++) {
                if (lt(array[j], array[smallest])) {
                    smallest = j;
                }
            }
            swap(array, i, smallest);
        }
    }
    /**
     * 插入法排序
     *
     * @param array
     */
    public static void InsertSort(int[] array) {
        for (int i = 1; i  array.length; i++) {
            int tmp = array;
            int j = i;
            while (j > 0 && array[j - 1] > tmp) {
                array[j] = array[j - 1];
                --j;
            }
            array[j] = tmp;
        }
    }
    /**
     * 希尔排序
     *
     * @param array
     */
    public static void ShellSort(int[] array) {
        for (int gap = array.length / 2; gap > 0; gap /= 2)
            for (int i = gap; i  array.length; i++)
                for (int j = i - gap; j >= 0; j -= gap)
                    if (gt(array[j], array[j + gap]))
                        swap(array, j, j + gap);
    }
    /**
     * 快速排序
     *
     * @param array
     * @param left
     * @param right
     */
    public static void QuickSort(int[] array) {
        sort(array, 0, array.length - 1);
    }
    /**
     * 快速排序算法
     *
     * @param array
     * @param left
     * @param right
     */
    private static void sort(int[] array, int left, int right) {
        int i = left, j = right;
        int middle = array[(left + right) / 2];
        do {
            while (lt(array, middle) && lt(i, right))
                i++;
            while (gt(array[j], middle) && gt(j, left))
                j--;
            if (i = j) {
                swap(array, i, j);
                i++;
                j--;
            }
        } while (i = j); // 如果两边扫描的下标交错,就停止(完成一次)
        if (lt(left, j))
            sort(array, left, j);
        if (gt(right, i))
            sort(array, i, right);
    }
    /**
     * 测试
     *
     * @param args
     */
    public static void main(String[] args) {
        int[] a = new int[] { 2, 4, 1, 67, 8, 50, 89, 34, 68, 4, 45 };
        // BubbleSort(a);
        // SelectSort(a);
        // InsertSort(a);
        // ShellSort(a);
        QuickSort(a);
        printArrays(a);
    }
}


本文来自ChinaUnix博客,如果查看原文请点:http://blog.chinaunix.net/u1/39379/showart_315847.html
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP