Java实现常见的排序算法代码实例

 更新时间:2023年11月23日 09:48:04   作者:chaojunma  
这篇文章主要介绍了Java实现常见的排序算法代码实例,按照思路实现了以下几个排序算法(冒泡排序、直接插入排序、直接选择排序、快速排序),方便日后用到,特此记录一下,需要的朋友可以参考下

Java排序算法代码实现

以前学习的各种排序算法都忘光了,也就记住了个冒泡算法,最近又学习了一下各个排序算法的思路,所以就按照思路实现了以下几个排序算法(冒泡排序、直接插入排序、直接选择排序、快速排序),方便日后用到,特此记录一下,以下为具体的实现。

代码

public class SortAlgorithm {
    public static void main(String[] args) {
        int[] nums = {6, 1, 4, 2, 3, 9, 5, 8, 7};
        // 冒泡排序
         bubbleSort(nums);
        // 直接插入排序
         insertSort(nums);
        // 直接选择排序
         directSelection(nums);
        // 快速选择排序
        int[] numbers = quickSort(nums, 0, nums.length -1);
        System.out.print("快速选择排序: ");
        for (int num : nums) {
            System.out.print(num + " ");
        }
        System.out.println();
    }
    public static void bubbleSort (int[] nums) {
        int temp;
        for (int i= 0;i <= nums.length; i++) {
            for (int j=i; j< nums.length-1; j++) {
                if (nums[j+1] < nums[j]) {
                    temp = nums[j+1];
                    nums[j+1] = nums[j];
                    nums[j] = temp;
                }
            }
        }
        System.out.print("冒泡排序: ");
        for (int num : nums) {
            System.out.print(num + " ");
        }
        System.out.println();
    }
    public static void insertSort(int[] nums) {
        // 存放有序的数组
        int[] numbers = new int[nums.length];
        int index = 0;
        for(int i=0;i< nums.length;i++) {
            // 当前待插入元素
            int current = nums[i];
            // 存放临时变量
            int prefix = 0;
            int temp = 0;
            // 未找到插入点
            boolean suc = false;
            // 插入第一个元素
            if (i == 0) {
                numbers[index] = current;
            } else {
                for(int j = 0; j < numbers.length; j++) {
                    // 找到待插入的点
                    if (numbers[j] > current || suc) {
                        // 未找到插入点
                        if (!suc) {
                            index = j;
                            suc = true;
                            // 记录下当前节点
                            prefix = numbers[j];
                        } else {
                            temp = numbers[j];
                            // 将前一个节点的值赋值给当前节点
                            numbers[j] = prefix;
                            prefix = temp;
                        }
                    }
                }
                // 若查找到插入节点
                if (suc) {
                    numbers[index] = current;
                } else {
                    numbers[i] = nums[i];
                }
            }
        }
        System.out.print("直接插入排序: ");
        for (int number : numbers) {
            System.out.print(number + " ");
        }
        System.out.println();
    }
    public static void directSelection(int[] nums) {
        int index = 0;
        for(int i=0; i < nums.length; i++) {
            // 默认不需要交换
            boolean exchange = false;
            int temp = nums[i];
            for(int j=i; j< nums.length; j++) {
                if (nums[j] < temp) {
                    // 寻找最小的值
                    temp = nums[j];
                    // 记录最小值的下标
                    index = j;
                    // 需要交换
                    exchange = true;
                }
            }
           // 需要交换,则进行交换
           if (exchange) {
               nums[index] = nums[i];
               // 将第i轮较小的值赋值给下标为i的节点
               nums[i] = temp;
           }
        }
        System.out.print("直接选择排序: ");
        for (int number : nums) {
            System.out.print(number + " ");
        }
        System.out.println();
    }
    public static int[] quickSort(int[] nums, int start, int end) {
        // 定义基准
        int k = nums[start];
        // 左侧定位到的下标
        int left = start;
        // 右侧定位到的下标
        int right = end;
        // 存放临时数据
        int temp;
        boolean compareLeft = false;
        while (left != right) {
            if (compareLeft) {
                if (nums[left] > k) {
                    temp = nums[right];
                    nums[right] = nums[left];
                    nums[left] = temp;
                    // 基准被踢到左侧,需要和左侧数据比较
                    compareLeft = false;
                } else {
                    left ++;
                }
            } else {
                if (nums[right] < k) {
                    temp = nums[left];
                    nums[left] = nums[right];
                    nums[right] = temp;
                    // 基准被踢到右侧,需要和左侧数据比较
                    compareLeft = true;
                } else {
                    right --;
                }
            }
        }
        if (left -1 > start) {
            quickSort(nums, start, left -1);
        }
        if (right + 1 < end) {
            quickSort(nums, right+ 1, end);
        }
        return nums;
    }
}

执行结果如下:

冒泡排序: 1 2 3 4 5 6 7 8 9 
直接插入排序: 1 2 3 4 5 6 7 8 9 
直接选择排序: 1 2 3 4 5 6 7 8 9 
快速选择排序: 1 2 3 4 5 6 7 8 9 

到此这篇关于Java实现常见的排序算法代码实例的文章就介绍到这了,更多相关Java排序算法代码内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Java实现万年历效果

    Java实现万年历效果

    这篇文章主要为大家详细介绍了Java实现万年历效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-06-06
  • vue2向springboot传值接收不到的解决方法

    vue2向springboot传值接收不到的解决方法

    本文主要介绍了vue2向springboot传值接收不到的解决方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-07-07
  • 浅谈Java垃圾回收机制

    浅谈Java垃圾回收机制

    Java 中,程序员不需要关心所有不再使用的对象。垃圾回收机制自动销毁这些对象。垃圾回收机制是守护线程的最佳示例,因为它始终在后台运行。垃圾回收机制的主要目标是通过销毁无法访问的对象来释放堆内存。下面我们就来详细介绍吧
    2021-09-09
  • Java基本语法笔记(菜鸟必看篇)

    Java基本语法笔记(菜鸟必看篇)

    下面小编就为大家带来一篇Java基本语法笔记(菜鸟必看篇)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-05-05
  • 使用javax.sound实现简单音频播放

    使用javax.sound实现简单音频播放

    这篇文章主要为大家详细介绍了使用javax.sound实现简单音频播放,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-03-03
  • 如何使用ByteArrayOutputStream下载文件

    如何使用ByteArrayOutputStream下载文件

    这篇文章主要介绍了如何使用ByteArrayOutputStream下载文件方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-12-12
  • Java网络编程UDP实现多线程在线聊天

    Java网络编程UDP实现多线程在线聊天

    这篇文章主要为大家详细介绍了Java网络编程UDP实现多线程在线聊天,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-07-07
  • Java Stream map, Collectors(toMap, toList, toSet, groupingBy, collectingAndThen)使用案例

    Java Stream map, Collectors(toMap, toLis

    这篇文章主要介绍了Java Stream map, Collectors(toMap, toList, toSet, groupingBy, collectingAndThen)使用案例,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-09-09
  • Java访问权限控制的重要性深入讲解

    Java访问权限控制的重要性深入讲解

    这篇文章主要给大家介绍了关于Java访问权限控制的重要性的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2018-11-11
  • Java中将base64编码字符串转换为图片的代码

    Java中将base64编码字符串转换为图片的代码

    这篇文章主要介绍了Java中将base64编码字符串转换为图片,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-03-03

最新评论