Java中常见的查找算法与排序算法总结

Java中常见的查找算法与排序算法总结

在Java中,我们经常需要对数据进行查找和排序。这里我们总结了常见的查找算法和排序算法。

查找算法

1. 顺序查找

顺序查找也叫线性查找,它的思想是从数据序列的一端开始,逐个比较数据,直到找到满足条件的数据或者遍历完整个序列。

以下是Java代码示例:

public static int sequenceSearch(int[] arr, int key) {
    for (int i = 0; i < arr.length; i++) {
        if (arr[i] == key) {
            return i;
        }
    }
    return -1;
}

2. 二分查找

二分查找也叫折半查找,它的思想是将有序数据序列分成若干个子序列,每次取中间位置的值与查找关键字进行比较,如果中间的值比查找的值大,则在左边子序列继续查找,否则在右边子序列继续查找,直到找到满足条件的值或者查找失败。

以下是Java代码示例:

public static int binarySearch(int[] arr, int key) {
    int low = 0;
    int high = arr.length - 1;
    while (low <= high) {
        int mid = (low + high) / 2;
        int midVal = arr[mid];
        if (midVal < key) {
            low = mid + 1;
        } else if (midVal > key) {
            high = mid - 1;
        } else {
            return mid;
        }
    }
    return -1;
}

排序算法

1. 冒泡排序

冒泡排序的思想是将相邻的两个数进行比较,如果顺序不对则进行交换,每次排序都会将最大(小)值移动到最后(前面)的位置。

以下是Java代码示例:

public static void bubbleSort(int[] arr) {
    int temp;
    for (int i = 0; i < arr.length - 1; i++) {
        for (int j = 0; j < arr.length - i - 1; j++) {
            if (arr[j] > arr[j + 1]) {
                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 partitionIndex = partition(arr, left, right);
        quickSort(arr, left, partitionIndex - 1);
        quickSort(arr, partitionIndex + 1, right);
    }
}

private static int partition(int[] arr, int left, int right) {
    int pivot = left;
    int index = pivot + 1;
    for (int i = index; i <= right; i++) {
        if (arr[i] < arr[pivot]) {
            swap(arr, i, index);
            index++;
        }
    }
    swap(arr, pivot, index - 1);
    return index - 1;
}

private static void swap(int[] arr, int i, int j) {
    int temp = arr[i];
    arr[i] = arr[j];
    arr[j] = temp;
}

以上就是Java中常见的查找算法和排序算法的总结。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:Java中常见的查找算法与排序算法总结 - Python技术站

(0)
上一篇 2023年5月19日
下一篇 2023年5月19日

相关文章

  • jabsorb笔记_几个小例子第1/2页

    jabsorb笔记_几个小例子第1/2页 什么是jabsorb jabsorb是一个 JavaScript 对象表示法 (JSON) 库,它将 Java 对象转换为 JSON 格式并反向转换。它具有很高的效率和灵活性,并且易于使用。 jabsorb的使用方法 jabsorb的使用非常简单,只需要引入jabsorb的jar包,然后创建一个JSONRPCBrid…

    Java 2023年6月15日
    00
  • SpringBoot 中使用JSP的方法示例

    Spring Boot是一个轻量级的框架,它可以快速地构建基于Java的Web应用程序。相比于Spring Framework而言,Spring Boot带来了更加方便的配置方式,同时也提供了一些默认的配置,让开发者快速构建应用程序。但是,在默认的情况下,Spring Boot并不支持JSP作为视图层,若要使用JSP需要另外进行配置。下面就是Spring B…

    Java 2023年6月15日
    00
  • 一篇超详细的Spring Boot整合Mybatis文章

    Spring Boot整合MyBatis完整攻略 Spring Boot是一个快速开发框架,可以帮助开发人员快速构建Web应用程序。在Spring Boot中,整合MyBatis可以帮助我们更方便地操作数据库。本文将介绍如何在Spring Boot中整合MyBatis,并提供两个示例。 整合MyBatis 在Spring Boot中整合MyBatis需要以下…

    Java 2023年5月15日
    00
  • 深入浅析Spring 中的Null-Safety

    深入浅析Spring 中的Null-Safety 简介 Null-Safety 是指在编程中对于空值(null)的处理,既避免了空指针异常,也提高了程序的健壮性和可维护性。在 Spring 中,Null-Safety 被广泛应用于各种场景,包括依赖注入、AOP 等等。本文将深入浅析 Spring 中的 Null-Safety,包括其原理、实现方法和示例。 原…

    Java 2023年5月31日
    00
  • 解析Java格式字符串的使用

    解析Java格式字符串的使用攻略 Java格式字符串是一种用来模板化字符串的特殊格式。Java提供了许多方法来解析和格式化Java格式字符串。本文将介绍如何使用Java中的格式化方法来解析Java格式字符串。 格式化方法 Java中的格式化方法有两种:字符串格式化方法和print格式化方法。 字符串格式化方法 字符串格式化方法是通过字符串中的格式占位符来实现…

    Java 2023年5月26日
    00
  • Java web实现购物车案例

    以下是“Java web实现购物车案例”的完整攻略: 1. 准备工作 首先,我们需要一些工具来实现Java web开发。具体来说,需要安装并配置以下软件:* JDK(Java Development Kit)* Tomcat服务器* Eclipse开发环境* MySQL数据库 2. 数据库设计 购物车需要记录商品和购买数量等信息,因此我们需要在MySQL数据…

    Java 2023年6月15日
    00
  • 快速排序的原理及java代码实现

    下面我来详细讲解一下“快速排序的原理及Java代码实现”的完整攻略。 1. 快速排序的原理 快速排序是一种常见的排序算法,其基本思想是:选择一个基准元素,将待排序序列分成两个子序列,使得左边的子序列元素都小于等于基准元素,右边的子序列元素都大于等于基准元素,然后递归地对子序列进行排序,直到整个序列有序。 具体的实现过程如下: 从待排序序列中选择一个基准元素,…

    Java 2023年5月19日
    00
  • JavaEE开发基于Eclipse的环境搭建以及Maven Web App的创建

    JavaEE是一种为企业应用而建的标准,它包含了很多技术(JSP、Servlet、Java Bean等)和规范(J2EE规范)的集合。而Eclipse是一个著名的Java IDE工具,通过它可以方便地进行JavaEE开发。下面将详细讲解如何基于Eclipse搭建JavaEE开发环境,并创建一个Maven Web App。 环境搭建 JDK安装及环境变量配置 …

    Java 2023年5月19日
    00
合作推广
合作推广
分享本页
返回顶部