JAVA数组的操作

部署运行你感兴趣的模型镜像

方法
1.遍历寻找最值
2.冒泡排序
3.选择排序
3.二分法查找元素位置

方法一  遍历寻找最值

需求:获取多个整数中最大的数
思路
1.用数组做容器存储需要比较的多个整数
2.多个数据需要比较。记录下每次比较较大的数
3.数组中的元素都比过一遍后,得出最大值
步骤
1.max初始化为数组中任意元素(或 max初始化为数组中任意角标)
2.max与数组元素进行比较,记录下更大的数(或 arr[max] 进行比较,记录下更大的角标)
3.遍历完得出结果

//很简单不写代码了

方法二  冒泡排序

需求:对多个无序整数数进行排序
以{10,9,23,66,8,32}为例
思路 :
1.0号与1号比较,将较大的数放在1放在1号,较小放在0号(交换位置)。后1号与2号比较,将较大的数放在2号。以此类推
2.第一轮比较完后,最大数出现在5号位
3.继续第二轮比较,共n-1轮
4.最后可以得到从小到大的排列
步骤
这里写图片描述

代码———————————————

//冒泡排序方法
public static void bubbleSort(int[] arr) {
        //外层循环,最多比较n-1轮
        for (int i = 0; x < arr.length - 1 ; i++) {
            //内层循环,从0比较到length-i-1
            for (int j = 0; j < arr.length - i - 1; j++) {
                //进行排序交换,大的放后面
                if (arr[j] > arr[j + 1]) {
                    int temp;
                    temp = arr[j];
                    arr[j] = arr[j + 1];
                    arr[j + 1] = temp;
                }
            }
        }
    }
    //打印数组方法
    public static void printArr(int[] arr){
        for(int x=0;x<arr.length;x++){
            System.out.println(arr[x]);
        }
    }
    //主方法
    public static void main(String[] args){
        int[] arr = new int[] {10,9,23,66,8,32};
        bubbleSort(arr);
        printArr(arr);
    }
方法三  选择排序

需求:对多个无序整数数进行排序
思路 :
还是以{10,9,23,66,8,32}为例
1.0号数与1号数比较,较小数放在0号,叫大数放在1号。然后0号数与2号比较,以此类推
2.第一轮比较完后,0号数为最小的数
3.继续第二轮比较,也是共n-1轮
4.最后得到从小到大的有序数列
步骤
这里写图片描述
代码————————————————-

    //选择排序方法
    public static void selectSort(int[] arr) {
        //外层循环,共n-1轮
        for (int i = 0; i < arr.length - 1 ; i++) {
            //从i+1数字开始向后比较,到最后一个数字
            for (int j = i + 1 ; j < arr.length ; j++) {
                //进行排序,交换位置,小的放前面
                if (arr[i] > arr[j]) {
                    int temp;
                    temp = arr[j];
                    arr[j] = arr[i];
                    arr[i] = temp;
                }
            }
        }
    }
    //打印数组方法
    public static void printArr(int[] arr){
        for(int x=0;x<arr.length;x++){
            System.out.println(arr[x]);
        }
    }
    //主方法
    public static void main(String[] args){
        int[] arr = new int[] {10,9,23,66,8,32};
        selectSort(arr);
        printArr(arr);
    }
方法四  二分法查找元素位置

需求:查找一个元素在有序数组中第一次出现的位置(有序才行)
思路
1.通过角标获取中间元素
2.该元素与要找的元素进行比较
3.如果该元素大,则取头角标与该元素角标的中间元素再次比较
4.以此类推
对于1,8,24,33,54,67,77,85,98,99
代码————————————————-

    //二分法
    public static int binarySearch(int[] arr, int key) {
        //最大角标,最小角标,中间角标
        int max, min, mid;
        //角标赋值
        min = 0;
        max = arr.length - 1;
        //循环条件
        while (min <= max) {
            //中间角标赋值
            mid = (max + min) >> 1;
            if (key > arr[mid])
                min = mid + 1;
            else if (key < arr[mid])
                max = mid - 1;
            //key=arr[mid]
            else
                //mid是在数组中的位置,加上0的位置1
                return mid + 1;
        }
        //如果数组中没有key返回 -1
        return -1;
    }
    //主方法
    public static void main(String[] args) {
        int[] arr = new int[] { 1, 8, 24, 33, 54, 67, 77, 85, 98, 99 };
        int s = binarySearch(arr, 99);
        System.out.println(s);
    }

:java.util包已经中有一个很强大的排序方法了,可以这样使用

代码————————————————-

//引入
import java.util.Arrays;

public class Sort {

    public static void main(String[] args) {
        int[] arr = new int[] { 1, 8, 24, 33, 54, 67, 77, 85, 98, 99 };
        //用已经提供的方法
        Arrays.sort(arr);
        //打印数组
        printArr(arr);
    }

    public static void printArr(int[] arr){
        for(int x=0;x<arr.length;x++){
            System.out.println(arr[x]);
        }
    }
}


您可能感兴趣的与本文相关的镜像

ComfyUI

ComfyUI

AI应用
ComfyUI

ComfyUI是一款易于上手的工作流设计工具,具有以下特点:基于工作流节点设计,可视化工作流搭建,快速切换工作流,对显存占用小,速度快,支持多种插件,如ADetailer、Controlnet和AnimateDIFF等

### 创建数组Java 中,数组的创建可以通过静态初始化或动态初始化实现。例如,静态初始化可以直接指定数组元素,而动态初始化则是在运行时确定数组的大小。以下是创建数组的示例代码: ```java // 静态初始化 int[] numbers = {1, 2, 3, 4, 5}; // 动态初始化 int[] dynamicNumbers = new int[5]; // 创建一个长度为5的数组 ``` ### 访问和修改数组元素 数组元素可以通过索引访问和修改。索引从0开始,直到数组长度减一。下面是如何访问和修改数组元素的例子: ```java // 修改数组元素 dynamicNumbers[0] = 10; // 将索引为0的元素值改为10 // 访问数组元素 System.out.println(dynamicNumbers[0]); // 输出索引为0的元素值 ``` ### 遍历数组 遍历数组通常使用循环结构,如 `for` 循环或者增强型 `for` 循环(for-each)。这使得可以轻松地访问数组中的每个元素: ```java // 使用 for 循环遍历数组 for (int i = 0; i < numbers.length; i++) { System.out.println(numbers[i]); } // 使用增强型 for 循环遍历数组 for (int number : numbers) { System.out.println(number); } ``` ### 多维数组 Java 支持多维数组,最常见的是二维数组。创建和访问多维数组的方式与一维数组类似,但需要额外的索引来访问特定维度的元素: ```java // 创建二维数组 int[][] matrix = new int[3][3]; // 初始化二维数组 matrix[0][0] = 1; matrix[0][1] = 2; matrix[0][2] = 3; matrix[1][0] = 4; matrix[1][1] = 5; matrix[1][2] = 6; matrix[2][0] = 7; matrix[2][1] = 8; matrix[2][2] = 9; // 访问二维数组元素 System.out.println(matrix[0][0]); // 输出1 ``` ### 数组的长度 每个数组都有一个 `length` 属性,用于获取数组的长度,即数组中元素的数量: ```java // 获取数组长度 System.out.println(numbers.length); // 输出5 ``` ### 数组的复制 Java 提供了多种方式来复制数组,包括使用 `System.arraycopy()` 方法、`Arrays.copyOf()` 方法等: ```java import java.util.Arrays; // 使用 Arrays.copyOf() 复制数组 int[] copyOfNumbers = Arrays.copyOf(numbers, numbers.length); ``` ### 数组的排序 可以使用 `Arrays.sort()` 方法对数组进行排序: ```java import java.util.Arrays; // 对数组进行排序 Arrays.sort(numbers); ``` ### 数组的查找 使用 `Arrays.binarySearch()` 方法可以在已排序的数组中查找特定元素的位置: ```java import java.util.Arrays; // 在已排序的数组中查找元素 int index = Arrays.binarySearch(numbers, 3); ``` ### 数组的比较 使用 `Arrays.equals()` 方法可以比较两个数组是否相等: ```java import java.util.Arrays; // 比较两个数组是否相等 boolean isEqual = Arrays.equals(numbers, copyOfNumbers); ``` ### 数组的填充 使用 `Arrays.fill()` 方法可以将数组的所有元素设置为特定值: ```java import java.util.Arrays; // 将数组所有元素设置为特定值 Arrays.fill(dynamicNumbers, 5); ``` ### 数组的转换 可以将数组转换为字符串形式,以便于输出或调试: ```java import java.util.Arrays; // 将数组转换为字符串 String arrayString = Arrays.toString(numbers); System.out.println(arrayString); // 输出 [1, 2, 3, 4, 5] ``` ### 数组的注意事项 在使用数组时需要注意以下几点: - 数组的大小是固定的,一旦创建后不能改变。 - 数组只能存储相同类型的元素。 - 数组的索引是从0开始的。 - 在访问数组元素时,确保索引不越界,否则会抛出 `ArrayIndexOutOfBoundsException` 异常。 通过上述方法和技巧,可以在 Java 中有效地进行数组操作。这些方法和技巧不仅涵盖了数组的基本操作,还包括了一些高级功能,如排序、查找、复制等,这些都是处理数组时不可或缺的工具。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值