0
点赞
收藏
分享

微信扫一扫

JAVA-数据结构-数组-附leetcode

鲤鱼打个滚 2022-03-12 阅读 98

JAVA-数据结构-数组-附leetcode

1.简介

在连续存储空间中,存储一组相同类型的元素

eg:

[1,2,3] yes [100,‘av’,13.14] no

假设下面是个内存块

1
2
3

no——链表


123

yes


数组a= [1,2,3]

数组元素指 1,2,3

数组索引指下标 0,1,2

数组访问 a[1] - >2 索引找元素

数组搜索 直接找2这个值 与索引无关


时间复杂度

访问O(n)
搜索O(n)
插入O(n)
删除O(n)

特点:适合读,不适合写

2.JAVA数组基本操作

2.1 创建数组

        //数组创建1 已知数组内容
        int[] a = {1,2,3};
        System.out.println("a:" + Arrays.toString(a));

        //数组创建2 已知数组内容
        int[] b = new int[]{1,2,3};
        System.out.println("b:" + Arrays.toString(b));

        //数组创建3 不知道数组内容,知道数组长度,先声明一块区域
        int[] c = new int[3];
        //可以之后添加
        for (int i = 0; i < c.length; i++) {
            c[i] = i;
        }
        System.out.println("c:" + Arrays.toString(c));

        //数组创建4 不知道数组内容,也不知道数组长度 - 一般用这个
        ArrayList<Integer> arr = new ArrayList<>();
        for (int i = 0; i < 3; i++) {
            arr.add(i+1);
        }
        System.out.println("arr:" + arr.toString());

2.2 添加元素

前三种需要先扩容

推荐第四种 直接调用方法

        //添加元素 默认添加尾部且尾部还有空间时间复杂度 O(1)
        //尾部没有空间,需要重新找内存扩容 再添加O(n)
        arr.add(9);
        System.out.println("arr:" + arr.toString()); 

        //插入 具体位置O(n)
        arr.add(3,8);
        System.out.println("arr:" + arr.toString());

2.3 访问元素O(1)

//访问元素
        int c1 = c[1];
        int arr1 = arr.get(1);
        System.out.println("c1:" + c1);
        System.out.println("arr1:" + arr1);

2.4 更新元素 O(1)

//更新元素
        c[1] = 11;
        arr.set(1,11);
        System.out.println("c1:" + c[1]);
        System.out.println("arr1:" + arr.get(1));

2.5 删除元素O(n)

前三种太麻烦,还是用第四种

//删除元素
        arr.remove(1);
        System.out.println("arr1:" + arr.get(1));

2.6 数组长度

创建的时候,内部有一个count变量,所以 O(1)

//数组长度
        int cSize = c.length;
        int arrSize = arr.size();
        System.out.println("c length:" + cSize);
        System.out.println("arrSize length:" + arrSize);

2.7 遍历数组 O(n)

  //遍历数组
        for (int i = 0; i < c.length; i++) {
            int current = c[i];
            System.out.println("c at index" + i +":" + current);
        }

        for (int i = 0; i < arr.size(); i++) {
            int current = arr.get(i);
            System.out.println("arr at index" + i +":" + current);
        }

2.8 查找元素 O(n)

//查找元素
for (int i = 0; i < c.length; i++) {
    if (c[i] == 0){
        System.out.println("yes! We found it ");
    }
}

boolean is9 = arr.contains(9);
System.out.println(is9);

2.9 数组排序 O(nlogN)

//数组排序
//重置 数组 乱序
c = new int[]{2,3,1};
arr = new ArrayList<>();
arr.add(2);
arr.add(3);
arr.add(1);
System.out.println("c:" + Arrays.toString(c));
System.out.println("arr:" + arr.toString());

//调用方法排序 从小到大 时间复杂度O(nlogN)
Arrays.sort(c);
Collections.sort(arr);
System.out.println("c:" + Arrays.toString(c));
System.out.println("arr:" + arr);
//从大到小
Collections.sort(arr,Collections.reverseOrder());
System.out.println("arr:" + arr);

3.Leetcode练习题

485

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-X9BUzgoE-1647087968467)(C:\Users\姜沣\Desktop\md图片\485.png)]

class Solution {
    public int findMaxConsecutiveOnes(int[] nums) {
        //数组为空直接 返回
        if(nums == null || nums.length == 0){
            return 0;
        }
        //设置两个值 标记一组的计数 和 目前标记的连续最大值
        int count = 0;
        int max = 0;
        for(int i = 0; i<nums.length; i++){
            if(nums[i] == 1){
                //是1 就计数++ 同时更新最大值
                count++;        
                max = Math.max(max,count);
            }else{
                //不是1 就重新计数
                count = 0;
            }
        }
        return max;
    }
}

283

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-iKODyveS-1647087968469)(C:\Users\姜沣\Desktop\md图片\283.png)]

class Solution {
    //题目难点 空间
    public void moveZeroes(int[] nums) {
        //设置一个值 统计0的值
        int count = 0;
        for(int i = 0; i < nums.length; i++){
            if(nums[i] == 0) count++;
        }

        //将非0值排在数组前面
        int index = 0;
        for(int i = 0; i<nums.length; i++){
            if(nums[i] != 0){
                nums[index++] = nums[i];
            }
        }

        //用0把剩下位置填满
        for(int i = 0; i<count; i++){
            nums[index++] =0;
        }

    }
}
上一思路简化版
class Solution {
    public void moveZeroes(int[] nums) {
        //设置标记
        int k = 0;
        for(int x : nums)
            if(x != 0) nums[k++] = x;
        while(k < nums.length)  nums[k++] = 0;      
    }
}

}

}

}


```java
上一思路简化版
class Solution {
    public void moveZeroes(int[] nums) {
        //设置标记
        int k = 0;
        for(int x : nums)
            if(x != 0) nums[k++] = x;
        while(k < nums.length)  nums[k++] = 0;      
    }
}
举报

相关推荐

0 条评论