数组常见算法

一、数组翻转:

1.概述:数组对称索引位置上的元素互换

写法一:

java 复制代码
public class Reverse {

    public static void main(String[] args) {
        
      int[] arr = {1, 2, 3, 4, 5, 6, 7};
        for (int min = 0, max = arr.length-1; min < max; min++, max--) {
            int temp = arr[min];
            arr[min] = arr[max];
            arr[max] = temp;
        }
        for (int i = 0; i < arr.length; i++) {
            System.out.print(arr[i] + " ");
        }

    }

}

写法二:

java 复制代码
public class ReverseT {
    public static void main(String[] args) {
        int[] arr = {1, 2, 3, 4, 5, 6, 7};
        int[] arrN = reverse(arr);
        for (int i = 0; i < arrN.length; i++) {
            System.out.print(arrN[i] + " ");
        }

    }
    public static int[] reverse(int[] arr){
        for (int min = 0,max = arr.length-1; min < max; min++,max--) {
            int temp = arr[min];
            arr[min] = arr[max];
            arr[max] = temp;
        }
        return arr;
    }

}

写法二用了新定义一个静态方法,然后用主类去调用方法来实现,但是要注意的是,直接在方法参数处是不允许初始化数组的,所以写法二会繁琐很多。

2.冒泡排序:进行数组元素的大小比较,然后进行位置交换;冒泡是相邻元素进行比较换位。

java 复制代码
public class Bubble {

    public static void main(String[] args) {

        int[] arr = {7,6,5,4,3,2,1};
        for (int l = 0; l < arr.length-1; l++) {
            for (int i = 0; i < arr.length-1; i++) {
                if (arr[i] > arr[i+1]){
                    int temp = arr[i];
                    arr[i] = arr[i+1];
                    arr[i+1] = temp;
                }
            }
        }
        for (int j = 0; j < arr.length; j++) {
            System.out.print(arr[j] + " ");
        }

    }


}

3.二分查找:

(1)前提:数组中的数据必须是有序的(所以在代码里,嵌套了上面的冒泡排序);

(2)思想:a.老式查找需要遍历数组,效率低;

b.二分法可以每次从中间数组查找,每次查询可以淘汰一半数据;

java 复制代码
public class Binary {
    public static void main(String[] args) {

        int[] arr = {3, 7, 5, 4, 3, 2, 1};
        for (int l = 0; l < arr.length - 1; l++) {
            for (int i = 0; i < arr.length - 1; i++) {
                if (arr[i] > arr[i + 1]) {
                    int temp = arr[i];
                    arr[i] = arr[i + 1];
                    arr[i + 1] = temp;
                }
            }
        }
        int index = binary(arr, 7);
        System.out.println(index);

    }
    public static int binary(int[] arr, int data){
        int max = arr.length-1;
        int min = 0;
        int mid = 0;
        while (min <= max){
            mid = (min + max)/2;
            if (data > arr[mid]){
                min = mid + 1;
            }else if(data < arr[mid]){
                max = mid -1;
            }else{
                return mid;
            }
        }
        return -1;
    }
}
相关推荐
云烟成雨TD15 小时前
Spring AI Alibaba 1.x 系列【6】ReactAgent 同步执行 & 流式执行
java·人工智能·spring
小O的算法实验室15 小时前
2026年ASOC,基于深度强化学习的无人机三维复杂环境分层自适应导航规划方法,深度解析+性能实测
算法·无人机·论文复现·智能算法·智能算法改进
于慨15 小时前
Lambda 表达式、方法引用(Method Reference)语法
java·前端·servlet
swg32132116 小时前
Spring Boot 3.X Oauth2 认证服务与资源服务
java·spring boot·后端
gelald16 小时前
SpringBoot - 自动配置原理
java·spring boot·后端
殷紫川16 小时前
深入理解 AQS:从架构到实现,解锁 Java 并发编程的核心密钥
java
‎ദ്ദിᵔ.˛.ᵔ₎16 小时前
LIST 的相关知识
数据结构·list
一轮弯弯的明月16 小时前
贝尔数求集合划分方案总数
java·笔记·蓝桥杯·学习心得
chenjingming66616 小时前
jmeter线程组设置以及串行和并行设置
java·开发语言·jmeter
殷紫川16 小时前
深入拆解 Java volatile:从内存屏障到无锁编程的实战指南
java