迹忆客 专注技术分享

当前位置:主页 > 学无止境 > 编程语言 > 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/12/17 浏览次数:217 分类:Java

本篇文章主要介绍如何在 Java 中制造程序延迟。本教程介绍了如何在 Java 中制造程序延时,并列举了一些示例代码来了解它。

如何在 Java 中把 Hashmap 转换为 JSON 对象

发布时间:2023/12/17 浏览次数:187 分类:Java

它描述了允许我们将哈希图转换为简单的 JSON 对象的方法。本文介绍了在 Java 中把 Hashmap 转换为 JSON 对象的方法。我们将看到关于创建一个 hashmap,然后将其转换为 JSON 对象的详细例子。

如何在 Java 中按值排序 Map

发布时间:2023/12/17 浏览次数:171 分类:Java

本文介绍了如何在 Java 中按值对 Map 进行排序。本教程介绍了如何在 Java 中按值对 Map 进行排序,并列出了一些示例代码来理解它。

如何在 Java 中打印 HashMap

发布时间:2023/12/17 浏览次数:192 分类:Java

本帖介绍了如何在 Java 中打印 HashMap。本教程介绍了如何在 Java 中打印 HashMap 元素,还列举了一些示例代码来理解这个主题。

在 Java 中更新 Hashmap 的值

发布时间:2023/12/17 浏览次数:146 分类:Java

本文介绍了如何在 Java 中更新 HashMap 中的一个值。本文介绍了如何在 Java 中使用 HashMap 类中包含的两个方法-put() 和 replace() 更新 HashMap 中的值。

Java 中的 hashmap 和 map 之间的区别

发布时间:2023/12/17 浏览次数:79 分类:Java

本文介绍了 Java 中的 hashmap 和 map 接口之间的区别。本教程介绍了 Java 中 Map 和 HashMap 之间的主要区别。在 Java 中,Map 是用于以键值对存储数据的接口,

在 Java 中获取用户主目录

发布时间:2023/12/17 浏览次数:218 分类:Java

这篇文章向你展示了如何在 Java 中获取用户主目录。本教程介绍了如何在 Java 中获取用户主目录,并列出了一些示例代码以指导你完成该主题。

Java 中 size 和 length 的区别

发布时间:2023/12/17 浏览次数:179 分类:Java

这篇文章教你如何知道 Java 中大小和长度之间的区别。本教程介绍了 Java 中大小和长度之间的区别。我们还列出了一些示例代码以帮助你理解该主题。

Java 中的互斥锁

发布时间:2023/12/17 浏览次数:111 分类:Java

了解有关 Java 中互斥锁的一切,在计算机科学领域,互斥或互斥被称为并发控制的属性。每台计算机都使用称为线程的最小程序指令序列。有一次,计算机在一个线程上工作。为了更好地理解,

扫一扫阅读全部技术教程

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

最新推荐

教程更新

热门标签

扫码一下
查看教程更方便