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

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(1)
搜索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

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

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;      
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
回答: 数组是多个相同类型数据的组合,用于实现对这些数据的统一管理。在Java中,数组可以包含任何数据类型,包括基本类型和引用类型。数组的下标从0开始,必须在指定范围内使用,否则会报下标越界异常。数组的赋值机制有两种情况,对于基本数据类型,赋的值是具体的数据,相互之间不影响;对于数组,默认情况下是引用传递,赋的值是地址。\[2\] 在解决LeetCode问题中,可以使用数组来存储和操作数据。例如,在解决两数之和问题时,可以使用HashMap来存储数组元素和对应的下标,然后遍历数组,判断目标值减去当前元素是否在HashMap中存在,如果存在,则返回对应的下标。这样可以在O(n)的时间复杂度内解决问题。\[1\] 在解决移除元素问题时,可以使用双指针的方法。定义一个慢指针和一个快指针,快指针用于遍历数组,慢指针用于指向不需要移除的元素。当快指针指向的元素不需要移除时,将其赋值给慢指针指向的位置,并将慢指针向后移动一位。最后返回慢指针的位置即可。这样可以在O(n)的时间复杂度内解决问题。\[3\] #### 引用[.reference_title] - *1* *2* [Java数据结构----数组](https://blog.csdn.net/automation666/article/details/130348201)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [Java-数据结构-数组](https://blog.csdn.net/weixin_45532984/article/details/125867222)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值