Java-数组[]-2

package Bibi.ArrayPack;

/**
 * @Package: Bibi.ArrayPack
 * @ClassName: ArrayTest1
 * @Date: 2020/12/2 8:36
 * @Description:
 */
public class ArrayTest1 {

    public static void func1() {
        int[] array1, array2;
        array1 = new int[]{2, 3, 5, 7, 11, 13, 17, 19};
        //不能称作数组的"复制(需要开辟新的空间)"
        array2 = array1;    //把地址给了array2,堆中只有一个数组
        for (int i = 0; i < array2.length; i++) {
            if (i % 2 == 0) {
                array2[i] = i;
            }
        }
        for (int i : array1) {
            System.out.println(i);
        }
    }

    public static void func2(){
        String[] arr = new String[]{"JJ", "DD", "MM", "BB", "GG", "AA"};
        String[] arr1 = new String[arr.length];
        for (int i = 0; i < arr1.length; i++) {
            arr1[i] = arr[i];
        }

        //数组的反转
        //方法一:
//        for (int i = 0; i < arr.length/2; i++) {
//            String temp = arr[i];
//            arr[i] = arr[arr.length - i - 1];
//            arr[arr.length - i - 1] = temp;
//        }
        //方法二:
//        for (int i = 0, j = arr.length-1; i < j; i++, j--) {
//            String temp = arr[i];
//            arr[i] = arr[j];
//            arr[j] = temp;
//        }

        //查找
        //线性查找:
        String dest = "BB";
        boolean isFlag = true;
        for (int i = 0; i < arr.length; i++) {
            if (dest.equals(arr[i])) {
                System.out.println("找到了指定的元素,位置为:" + i);
                isFlag = false;
                break;
            }
        }
        if (isFlag) {
            System.out.println("没找到");
        }

        //二分法查找(有序数组):
        int[] arr2 = new int[]{-98, -34, 2, 34, 54, 66, 79, 105, 210, 333};
        int dest2 = -34;
        int head = 0, tail = arr2.length-1;
        boolean isFlag2 = true;
        while (head <= tail) {
            int middle = (tail - head)/2 + head;
            if (dest2 == arr2[middle]) {
                System.out.println("找到了指定的元素,位置为:" + middle);
                isFlag2 = false;
                break;
            } else if (arr2[middle] > dest2) {
                tail = middle - 1;
            } else {
                head = middle + 1;
            }
        }
        if (isFlag2) {
            System.out.println("没找到");
        }
    }

    public static void main(String[] args) {
        func2();
    }
}

package Bibi.ArrayPack;

import java.util.Arrays;

/**
 * @Package: Bibi.ArrayPack
 * @ClassName: ArraySortTest
 * @Date: 2020/12/2 10:04
 * @Description:
 */
public class ArraySortTest {

    public static void bubbleSort() {
        //冒泡排序(比较相邻)
        int[] arr = new int[]{89, 12, 34, 67, 45, 10};
        for (int i = 0; i < arr.length-1; i++) {
            for (int j = 0; j < arr.length-1-i; j++) {
                if (arr[j] > arr[j+1]) {
                    int temp = arr[j];
                    arr[j] = arr[j+1];
                    arr[j+1] = temp;
                }
            }
        }
        System.out.println(Arrays.toString(arr));
    }

    public static void quickSort() {}

    public static void func1() {
        //Arrays操作数组的工具类
        int[] arr1 = new int[]{1, 2, 2, 3};
        int[] arr2 = new int[]{1, 2, 2, 3};
        System.out.println(Arrays.equals(arr1, arr2));
        System.out.println(Arrays.toString(arr1));
        Arrays.fill(arr2, 10);
        System.out.println(Arrays.toString(arr2));
        System.out.println(Arrays.binarySearch(arr1, 2));
    }

    public static void func2() {
        //数组中的常见异常
        //1.数组下标越界异常ArrayIndexOutOfBoundsException
        //2.空指针异常NullPointerException
//        int[] res = new int[]{1, 2, 3};
//        res = null;
//        System.out.println(res[1]);
    }

    public static void main(String[] args) {
        func2();
    }
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值