滚雪球学Java(33):数组算法大揭秘:应用案例实战分享

简介: 【5月更文挑战第8天】🏆本文收录于「滚雪球学Java」专栏,专业攻坚指数级提升,希望能够助你一臂之力,帮你早日登顶实现财富自由🚀;同时,欢迎大家关注&&收藏&&订阅!持续更新中,up!up!up!!

🏆本文收录于「滚雪球学Java」专栏,专业攻坚指数级提升,助你一臂之力,带你早日登顶🚀,欢迎大家关注&&收藏!持续更新中,up!up!up!!


前言

数组是最常用的数据结构之一,在各种编程语言中都有广泛应用。在Java中,数组可以直接使用,也可以通过集合框架中的List、Set等数据结构来实现。但是,在实际开发中,我们常常需要对数组进行一些操作,比如排序、查找、过滤等。这些操作需要使用一些数组算法。

本文将介绍一些常用的数组算法,包括排序、查找、过滤等。我们将通过实际案例来展示这些算法的应用。我们将使用Java编程语言来实现这些算法,并且提供源代码、方法介绍、测试用例等详细信息。希望本文能够帮助您更好地理解数组算法。

摘要

本文将介绍以下几种数组算法:

  1. 冒泡排序算法
  2. 快速排序算法
  3. 二分查找算法
  4. 过滤算法

我们将通过实际案例来展示这些算法的应用,并提供源代码、方法介绍、测试用例等详细信息。

正文

1. 冒泡排序算法

冒泡排序是一种简单的排序算法,它的基本思想是比较相邻的元素。如果第一个比第二个大,就交换它们两个。对第一轮排序后,在剩下的元素中再进行第二轮排序,以此类推。这样每一轮排序结束后,都会将最大的元素排到最后面。

以下是冒泡排序算法的Java实现:

public static void bubbleSort(int[] arr) {
   
    int n = arr.length;
    for (int i = 0; i < n - 1; i++) {
   
        for (int j = 0; j < n - i - 1; j++) {
   
            if (arr[j] > arr[j + 1]) {
   
                int temp = arr[j];
                arr[j] = arr[j + 1];
                arr[j + 1] = temp;
            }
        }
    }
}

上面的代码中,我们使用了两个嵌套循环来实现冒泡排序。外层循环控制排序轮数,内层循环控制比较的次数。在内层循环中,我们比较相邻的元素,如果前面的元素比后面的大,就交换它们两个。

2. 快速排序算法

快速排序是一种常用的排序算法,它的基本思想是挖坑填数。具体来说,我们先从数列中取出一个数作为基准数,然后将比它小的数放在左边,比它大的数放在右边。接着,我们再对左右两边的子数列进行递归处理,直到整个序列有序为止。

以下是快速排序算法的Java实现:

public static void quickSort(int[] arr, int left, int right) {
   
    if (left < right) {
   
        int i = left;
        int j = right;
        int pivot = arr[left];
        while (i < j) {
   
            while (i < j && arr[j] >= pivot) {
   
                j--;
            }
            if (i < j) {
   
                arr[i] = arr[j];
                i++;
            }
            while (i < j && arr[i] < pivot) {
   
                i++;
            }
            if (i < j) {
   
                arr[j] = arr[i];
                j--;
            }
        }
        arr[i] = pivot;
        quickSort(arr, left, i - 1);
        quickSort(arr, i + 1, right);
    }
}

上面的代码中,我们使用了递归来实现快速排序。在每一轮排序中,我们首先选取一个基准数,然后从序列的两端开始比较,将比基准数小的数放在左边,比基准数大的数放在右边。在比较过程中,我们使用两个指针i和j来记录左右两边位置,最后将基准数插入到i的位置。

3. 二分查找算法

二分查找是一种常用的查找算法,它的基本思想是将查找区间不断缩小,直到找到目标元素或者查找区间为空。具体来说,我们先将查找区间定为整个序列,然后取中间位置的元素与目标元素比较。如果中间位置的元素等于目标元素,则直接返回该位置。如果中间位置的元素小于目标元素,则查找区间缩小到右半部分。否则查找区间缩小到左半部分。重复上述过程,直到找到目标元素或者查找区间为空。

以下是二分查找算法的Java实现:

public static int binarySearch(int[] arr, int target) {
   
    int left = 0;
    int right = arr.length - 1;
    while (left <= right) {
   
        int mid = (left + right) / 2;
        if (arr[mid] == target) {
   
            return mid;
        } else if (arr[mid] < target) {
   
            left = mid + 1;
        } else {
   
            right = mid - 1;
        }
    }
    return -1;
}

上面的代码中,我们使用了循环来实现二分查找。在每一轮查找中,我们首先计算中间位置mid,然后将中间位置的元素与目标元素比较。如果相等,则直接返回中间位置。如果目标元素小于中间元素,则将查找区间缩小到左半部分。如果目标元素大于中间元素,则将查找区间缩小到右半部分。重复上述过程,直到找到目标元素或者查找区间为空。

4. 过滤算法

过滤算法是一种常用的数组处理算法,它的基本思想是筛选符合要求的元素,并将它们存放在一个新的数组中。具体来说,我们首先遍历原数组中的每一个元素,然后判断它是否符合某个条件。如果符合条件,则将它存放在新数组中。最后返回新数组。

以下是过滤算法的Java实现:

public static int[] filter(int[] arr, Filter filter) {
   
    int[] result = new int[arr.length];
    int count = 0;
    for (int i = 0; i < arr.length; i++) {
   
        if (filter.filter(arr[i])) {
   
            result[count++] = arr[i];
        }
    }
    return Arrays.copyOf(result, count);
}

public interface Filter {
   
    boolean filter(int value);
}

上面的代码中,我们为过滤算法定义了一个Filter接口,用于表示过滤条件。在filter方法中,我们首先创建一个新数组result,并定义一个count变量计数符合条件的元素个数。然后遍历原数组中的每一个元素,如果符合条件,则将它存放在新数组中,并将count加1。最后,我们使用Arrays.copyOf方法将新数组缩小到count大小,并返回新数组。

测试用例

1. 冒泡排序算法

public class BubbleSort {
   
    public static void bubbleSort(int[] arr) {
   
        int len = arr.length;
        for (int i = 0; i < len - 1; i++) {
   
            for (int j = 0; j < len - 1 - i; j++) {
   
                if (arr[j] > arr[j + 1]) {
   
                    int temp = arr[j];
                    arr[j] = arr[j + 1];
                    arr[j + 1] = temp;
                }
            }
        }
    }

    public static void main(String[] args) {
   
        int[] arr = {
   5, 3, 8, 6, 4};
        bubbleSort(arr);
        for (int i : arr) {
   
            System.out.print(i + " ");
        }
    }
}

输出结果:

3 4 5 6 8

2. 快速排序算法

public class QuickSort {
   
    public static void quickSort(int[] arr, int left, int right) {
   
        if (left < right) {
   
            int i = left;
            int j = right;
            int pivot = arr[left];
            while (i < j) {
   
                while (i < j && arr[j] >= pivot) {
   
                    j--;
                }
                if (i < j) {
   
                    arr[i++] = arr[j];
                }
                while (i < j && arr[i] <= pivot) {
   
                    i++;
                }
                if (i < j) {
   
                    arr[j--] = arr[i];
                }
            }
            arr[i] = pivot;
            quickSort(arr, left, i - 1);
            quickSort(arr, i + 1, right);
        }
    }

    public static void main(String[] args) {
   
        int[] arr = {
   5, 3, 8, 6, 4};
        quickSort(arr, 0, arr.length - 1);
        for (int i : arr) {
   
            System.out.print(i + " ");
        }
    }
}

输出结果:

3 4 5 6 8

3. 二分查找算法

public class BinarySearch {
   
    public static int binarySearch(int[] arr, int target) {
   
        int left = 0;
        int right = arr.length - 1;
        while (left <= right) {
   
            int mid = left + (right - left) / 2;
            if (arr[mid] == target) {
   
                return mid;
            } else if (arr[mid] > target) {
   
                right = mid - 1;
            } else {
   
                left = mid + 1;
            }
        }
        return -1;
    }

    public static void main(String[] args) {
   
        int[] arr = {
   1, 2, 3, 4, 5};
        int target = 4;
        int index = binarySearch(arr, target);
        System.out.println(index);
    }
}

输出结果:

3

4. 过滤算法

import java.util.ArrayList;
import java.util.List;

public class FilterAlgorithm {
   
    public static List<Integer> filter(List<Integer> list) {
   
        List<Integer> result = new ArrayList<>();
        for (int i : list) {
   
            if (i % 2 == 0) {
   
                result.add(i);
            }
        }
        return result;
    }

    public static void main(String[] args) {
   
        List<Integer> list = new ArrayList<>();
        list.add(1);
        list.add(2);
        list.add(3);
        list.add(4);
        list.add(5);
        List<Integer> result = filter(list);
        for (int i : result) {
   
            System.out.print(i + " ");
        }
    }
}

输出结果:

2 4

附录源码

  如上涉及所有源码均已上传同步在 Gitee,提供给同学们一对一参考学习,辅助你更迅速的掌握。

☀️建议/推荐你


  无论你是计算机专业的学生,还是对编程有兴趣的小伙伴,都建议直接毫无顾忌的学习此专栏「滚雪球学Java」,bug菌郑重承诺,凡是学习此专栏的同学,均能获取到所需的知识和技能,全网最快速入门Java编程,就像滚雪球一样,越滚越大,指数级提升。

目录
相关文章
|
2月前
|
存储 算法 Java
解析HashSet的工作原理,揭示Set如何利用哈希算法和equals()方法确保元素唯一性,并通过示例代码展示了其“无重复”特性的具体应用
在Java中,Set接口以其独特的“无重复”特性脱颖而出。本文通过解析HashSet的工作原理,揭示Set如何利用哈希算法和equals()方法确保元素唯一性,并通过示例代码展示了其“无重复”特性的具体应用。
54 3
|
24天前
|
机器学习/深度学习 人工智能 算法
探索人工智能中的强化学习:原理、算法与应用
探索人工智能中的强化学习:原理、算法与应用
|
23天前
|
机器学习/深度学习 算法 数据挖掘
C语言在机器学习中的应用及其重要性。C语言以其高效性、灵活性和可移植性,适合开发高性能的机器学习算法,尤其在底层算法实现、嵌入式系统和高性能计算中表现突出
本文探讨了C语言在机器学习中的应用及其重要性。C语言以其高效性、灵活性和可移植性,适合开发高性能的机器学习算法,尤其在底层算法实现、嵌入式系统和高性能计算中表现突出。文章还介绍了C语言在知名机器学习库中的作用,以及与Python等语言结合使用的案例,展望了其未来发展的挑战与机遇。
39 1
|
23天前
|
并行计算 算法 测试技术
C语言因高效灵活被广泛应用于软件开发。本文探讨了优化C语言程序性能的策略,涵盖算法优化、代码结构优化、内存管理优化、编译器优化、数据结构优化、并行计算优化及性能测试与分析七个方面
C语言因高效灵活被广泛应用于软件开发。本文探讨了优化C语言程序性能的策略,涵盖算法优化、代码结构优化、内存管理优化、编译器优化、数据结构优化、并行计算优化及性能测试与分析七个方面,旨在通过综合策略提升程序性能,满足实际需求。
54 1
|
1月前
|
缓存 算法 网络协议
OSPF的路由计算算法:原理与应用
OSPF的路由计算算法:原理与应用
46 4
|
1月前
|
机器学习/深度学习 监控 算法
基于反光衣和检测算法的应用探索
本文探讨了利用机器学习和计算机视觉技术进行反光衣检测的方法,涵盖图像预处理、目标检测与分类、特征提取等关键技术。通过YOLOv5等模型的训练与优化,展示了实现高效反光衣识别的完整流程,旨在提升智能检测系统的性能,应用于交通安全、工地监控等领域。
|
1月前
|
存储 算法 网络协议
OSPF的SPF算法介绍:原理、实现与应用
OSPF的SPF算法介绍:原理、实现与应用
78 3
|
1月前
|
机器学习/深度学习 JSON 算法
二叉树遍历算法的应用场景有哪些?
【10月更文挑战第29天】二叉树遍历算法作为一种基础而重要的算法,在许多领域都有着不可或缺的应用,它为解决各种复杂的问题提供了有效的手段和思路。随着计算机科学的不断发展,二叉树遍历算法也在不断地被优化和扩展,以适应新的应用场景和需求。
43 0
|
24天前
|
机器学习/深度学习 人工智能 算法
探索人工智能中的强化学习:原理、算法及应用
探索人工智能中的强化学习:原理、算法及应用
|
2月前
|
存储 缓存 算法
Java 数组
【10月更文挑战第19天】Java 数组是一种非常实用的数据结构,它为我们提供了一种简单而有效的方式来存储和管理数据。通过合理地使用数组,我们能够提高程序的运行效率和代码的可读性。更加深入地了解和掌握 Java 数组的特性和应用,为我们的编程之旅增添更多的精彩。
33 4