迹忆客 专注技术分享

当前位置:主页 > 学无止境 > 编程语言 > Java >

在 Java 中使用 ArrayList 进行合并排序

作者:迹忆客 最近更新:2023/05/16 浏览次数:

本教程介绍了在 Java 中使用 ArrayList 执行合并排序所需的步骤。合并排序使用分治法对数组或 ArrayList 中的项目进行排序。


在 Java 中使用 ArrayList 进行合并排序

我们需要两个函数来执行归并排序;第一个功能是将我们要排序的 ArrayList 分成两半,即我们将 ArrayList 从中间分开,然后调用自身,直到它们完全分开。

第二种方法是将分割的元素合并成一个单一的 ArrayList。这是我们得到排序的 ArrayList 的时候。

在下面的例子中,我们创建了一个名为 arrayToSortArrayList 实例,它保存整数值。我们在 ExampleClass1 构造函数中初始化列表。

现在我们创建两个方法,divideArrayElements()mergeArrayElements

divideArrayElements()indexStartindexEnd 作为参数来标识从哪个索引开始以及在哪里结束。在方法内部,我们检查 indexStart 是否小于 indexEnd 以及它们的差是否不大于 1。

在条件语句中,我们使用 (indexEnd + indexStart) / 2 获得 ArrayList 的中间元素,它将 ArrayList 分成两半。

现在通过调用 divideArrayElements() 划分已经划分的 ArrayList,并将 indexStart 作为起始索引,将 middleElement 作为结束索引。

这样做是为了打破分割的 ArrayList。为了分割后半部分,我们再次调用 divideArrayElements() 方法并将 middleElement + 1 作为其开始索引和 indexEnd

请注意,我们正在递归调用 divideArrayElements() 方法。下一步是通过调用方法 mergeArrayElements() 对分割后的 ArrayList 元素进行合并和排序,在该方法中我们传递开始索引、中间索引和结束索引。

mergeArrayElements() 函数中,我们创建了一个临时合并元素的 ArrayList。然后我们需要左索引和右索引来知道合并元素的起点和终点。

我们使用一个循环,直到 getLeftIndexgetRightIndex 小于 indexMiddleindexEnd

现在在循环中,我们检查 tempArray 中元素的值是否在左侧索引上小于右侧索引,如果是,则将左侧索引上的值添加到 ArrayList 中,并且增加 getLeftIndex 值。

如果左索引大于右索引,我们在列表中插入右索引值。

我们还创建了两个单独的循环来检查左侧索引是否小于中间索引,另一个循环来检查右侧索引是否小于结束索引。最后,我们将临时的 ArrayList 设置为 arrayToSort 列表。

我们在 main() 方法中创建列表来排序和插入一些值。我们创建一个 ExampleClass1 类的对象,并在其构造函数中传递列表。

使用返回列表的 getArrayAfterSorting() 来获取 ArrayList。第一个输出显示调用 divideArrayElements() 之前的列表,第二个输出显示排序后的列表。

import java.util.ArrayList;

public class ExampleClass1 {
    private final ArrayList<Integer> arrayToSort;

    public ExampleClass1(ArrayList<Integer> arrayToSort) {
        this.arrayToSort = arrayToSort;
    }

    public ArrayList<Integer> getArrayAfterSorting() {
        return arrayToSort;
    }

    public void divideArrayElements(int indexStart, int indexEnd) {

        if (indexStart < indexEnd && (indexEnd - indexStart) >= 1) {
            int middleElement = (indexEnd + indexStart) / 2;

            divideArrayElements(indexStart, middleElement);
            divideArrayElements(middleElement + 1, indexEnd);

            mergeArrayElements(indexStart, middleElement, indexEnd);
        }
    }

    public void mergeArrayElements(int indexStart, int indexMiddle, int indexEnd) {

        ArrayList<Integer> tempArray = new ArrayList<>();

        int getLeftIndex = indexStart;
        int getRightIndex = indexMiddle + 1;

        while (getLeftIndex <= indexMiddle && getRightIndex <= indexEnd) {

            if (arrayToSort.get(getLeftIndex) <= arrayToSort.get(getRightIndex)) {

                tempArray.add(arrayToSort.get(getLeftIndex));
                getLeftIndex++;

            } else {

                tempArray.add(arrayToSort.get(getRightIndex));
                getRightIndex++;

            }
        }

        while (getLeftIndex <= indexMiddle) {
            tempArray.add(arrayToSort.get(getLeftIndex));
            getLeftIndex++;
        }

        while (getRightIndex <= indexEnd) {
            tempArray.add(arrayToSort.get(getRightIndex));
            getRightIndex++;
        }


        for (int i = 0; i < tempArray.size(); indexStart++) {
            arrayToSort.set(indexStart, tempArray.get(i++));

        }

    }

    public static void main(String[] args) {
        ArrayList<Integer> integerArrayList = new ArrayList<>();
        integerArrayList.add(23);
        integerArrayList.add(44);
        integerArrayList.add(12);
        integerArrayList.add(3);
        integerArrayList.add(76);

        ExampleClass1 exampleClass1 = new ExampleClass1(integerArrayList);

        System.out.println("Array Before Merge Sort: ");
        for (Integer integer : exampleClass1.getArrayAfterSorting()) {
            System.out.println(integer);
        }

        System.out.println();

        exampleClass1.divideArrayElements(0, integerArrayList.size() - 1);

        System.out.println("Array After Merge Sort: ");
        for (Integer integer : exampleClass1.getArrayAfterSorting()) {
            System.out.println(integer);
        }


    }
}

输出:

Array Before Merge Sort:
23
44
12
3
76

Array After Merge Sort:
3
12
23
44
76

转载请发邮件至 1244347461@qq.com 进行申请,经作者同意之后,转载请以链接形式注明出处

本文地址:

相关文章

Java 中的纸牌洗牌

发布时间:2023/05/16 浏览次数:72 分类:Java

本文介绍如何在 Java 中洗一副牌。使用 Java 中的传统循环打乱 ArrayList。类似地,在 Java 中,各种方法允许用户随机播放元素。下面是演示此过程的代码块。

Java 中将列表转换为 ArrayList

发布时间:2023/05/16 浏览次数:155 分类:Java

在 Java 中将 List 转换为 ArrayList 的方法。在本篇文章中,我们讨论了如何在 Java 中将列表转换为 ArrayList。

Java 中 ArrayList 和 LinkedList 的区别

发布时间:2023/05/16 浏览次数:126 分类:Java

本文介绍 Java 中 ArrayList 和 LinkedList 的区别。ArrayList 和 LinkedList 都用于存储数据,但由于实现类型的不同而存在一些差异。

在 Java 中将 ArrayList 转换为 Set

发布时间:2023/05/16 浏览次数:182 分类:Java

本文介绍 Java 中 ArrayList 到 Set 的转换。ArrayList 是 List 接口的实现类,用于以线性顺序存储数据,而 set 是具有 HashSet 类来存储数据的接口。

在 Java 中将 ArrayList 转换为 Int 数组

发布时间:2023/05/16 浏览次数:95 分类:Java

本文讨论了在 Java 中将 ArrayList 转换为 int Array 的四种方法。使用 for 循环将 Arraylist 转换为 Int 数组; 使用 Object[] toArray() 函数将 Arraylist 转换为 Int 数组

Java 中比较 ArrayList

发布时间:2023/05/16 浏览次数:137 分类:Java

在本教程中,首先,我们将使用 Java 中的比较方法比较两个数组列表。在将其应用于数组列表之前,我们还将相同的方法应用于 Java 字符串。最后,我们演示了如何在比较之前对无序列

Java 中将字节转换为整数

发布时间:2023/05/16 浏览次数:139 分类:Java

本文重点介绍如何使用 Byte Wrapper Class 和 Casting 在 Java 中将字节转换为 int 数据类型。字节数据类型定义为 8 位有符号二进制补码整数,而 int 数据类型可归类为 32 位有符号二进制补码整数。除

扫一扫阅读全部技术教程

社交账号
  • https://www.github.com/onmpw
  • qq:1244347461

最新推荐

教程更新

热门标签

扫码一下
查看教程更方便