Java 数组高频考点分析讲解

 更新时间:2022年04月02日 16:57:53   作者:Scintillator. /  
数组对于每一门编程语言来说都是重要的数据结构之一,当然不同语言对数组的实现及处理也不尽相同。Java 语言中提供的数组是用来存储固定大小的同类型元素

1、数组理论基础

数组是存放在连续内存空间上的相同类型数据的集合,可以通过下标索引的方式获取到下标下对应的数据。

举个栗子(字符数组)~

在这里插入图片描述

可以看到:

1、数组的下标从0开始

2、数组在内存中的地址是连续的

所以在删除元素时,只能用覆盖的方式进行。

例如,要删除下标为2的元素~ 就需要将从2之后的元素依次移到前一个,覆盖掉要删除的元素。

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

所以删除元素并不是将该元素的空间释放了,而是将后面的元素移到前面,覆盖掉要删除的元素,然后将数组的长度减去1,就能得到一个看似新的数组。

在java中,二维数组的存储方式如下:

在这里插入图片描述

2、常见考点

1.二分查找

力扣题目链接: 二分查找

这道题目的前提是有序数组,因为一旦有重复元素,使用二分查找法返回的元素下标可能不是唯一的,这些都是使用二分法的前提条件。

二分查找思想是:

数组有序的前提下(假设升序),如果数组中间的值大于要查找的值,那么要查找的元素就不可能在后半部分,因为后半部分的值都大于中间的值,所以通过第一次比较,就可以将范围缩小一半,后面同理,即时间复杂度降到了O(logN),效率大大提高,当题目中要求查找元素的时间复杂度为O(logN)时,首先想一想是否能用二分呢?

class Solution {
    public int search(int[] nums, int target) {
        // 避免当 target 小于nums[0] nums[nums.length - 1]时多次循环运算
        if (target < nums[0] || target > nums[nums.length - 1]) {
            return -1;
        }
        int left = 0, right = nums.length - 1;
        while (left <= right) {
            int mid = left + ((right - left) >> 1);
            if (nums[mid] == target)
                return mid;
            else if (nums[mid] < target)
                left = mid + 1;
            else if (nums[mid] > target)
                right = mid - 1;
        }
        return -1;
    }
}

2.移除元素

有的同学可能说了,多余的元素,删掉不就得了?但是要知道数组的元素在内存地址中是连续的,不能单独删除数组中的某个元素,只能覆盖。

例如:给你一个数组和一个val值,要求删除数组中等于val值的元素,怎么做呢?

思路1:暴力法

我们可以使用两个for循环,当遍历到等于val值的元素时,就将后面的元素整体往前移一个覆盖掉要删除的元素,但是这种做法显然时间复杂度太高。

class Solution {
    public int removeElement(int[] nums, int val) {
        int size = nums.length;
        for (int i = 0; i < size;i++ ) {
            if (nums[i] == val) { // 发现需要移除的元素,就将数组后面集体向前移动一位
                for (int j = i + 1; j < size; j++) {
                    nums[j - 1] = nums[j];
                }
                i--; // 因为下标i以后的数值都向前移动了一位,所以i也向前移动一位
                size--;
            }
        }
        return size;
    }
}

思路2:双指针法

分别设设一个快慢指针,slow fast ,两者一起走,当慢指针遇到要删除的元素时停下,等待着被删除(覆盖);当快指针走到要被留下的元素时,将快指针的元素赋值给慢指针,然后两指针同时向后走,直到快指针遍历完整个数组。

可以这么理解:定义数组的新长度newLength ,从0开始,定义一个快指针遍历数组 fast,当fast走到要被留下的元素时,说明该元素应该被添加到新数组中(即被添加到newLength 下标,这里相当于 newLength 之前的部分数组看做要返回的新数组,相当于往这个新数组里插入元素)。

class Solution {
    public int removeElement(int[] nums, int val) {
        int fast = 0;// 定义一个快指针遍历数组
        int newLength = 0;// 定义新的数组长度
        while(fast < nums.length){
            if(nums[fast] != val){
                nums[newLength++] = nums[fast];
            }
            fast++;
        }
        return newLength;
    }
}

推荐力扣题目

1.删除排序数组中的重复项

2.移动零

3.比较含退格的字符串

4.有序数组的平方

其他常见数组的考点很多都是以这两点为基础,无非就是对数组增删改查,将数组的查找和删除掌握了,就可以开始刷题啦。

到此这篇关于Java 数组高频考点分析讲解的文章就介绍到这了,更多相关Java 数组内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • springboot异常处理的基本规范

    springboot异常处理的基本规范

    这篇文章主要给大家介绍了关于springboot异常处理的基本规范,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-11-11
  • Spring详细讲解事务失效的场景

    Spring详细讲解事务失效的场景

    实际项目开发中,如果涉及到多张表操作时,为了保证业务数据的一致性,大家一般都会采用事务机制,好多小伙伴可能只是简单了解一下,遇到事务失效的情况,便会无从下手,下面这篇文章主要给大家介绍了关于Spring事务失效场景的相关资料,需要的朋友可以参考下
    2022-07-07
  • Java中Lambda表达式并行与组合行为

    Java中Lambda表达式并行与组合行为

    这篇文章主要介绍了Java中Lambda表达式并行与组合行为,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2017-02-02
  • java使用poi读取ppt文件和poi读取excel、word示例

    java使用poi读取ppt文件和poi读取excel、word示例

    这篇文章主要介绍了java使用poi读取ppt文件和poi读取excel、word示例,需要的朋友可以参考下
    2014-03-03
  • springboot+mybatis-plus基于拦截器实现分表的示例代码

    springboot+mybatis-plus基于拦截器实现分表的示例代码

    本文主要介绍了springboot+mybatis-plus基于拦截器实现分表,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-11-11
  • swagger2和knife4j的详细使用教程(入门级)

    swagger2和knife4j的详细使用教程(入门级)

    最近项目中用到了Swagger2和knife4j作为接口文档,所以下面这篇文章主要给大家介绍了关于swagger2和knife4j的详细使用教程,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2022-09-09
  • 如何使用Java语言编写打地鼠游戏全过程

    如何使用Java语言编写打地鼠游戏全过程

    打地鼠是我们非常熟悉的一款小游戏,它的游戏结构和规则也都比较简单,那么如果能够亲自徒手开发这样的一款经典小游戏呢?这篇文章主要给大家介绍了关于如何使用Java语言编写打地鼠游戏的相关资料,需要的朋友可以参考下
    2024-06-06
  • java实现列表、集合与数组之间转化的方法

    java实现列表、集合与数组之间转化的方法

    这篇文章主要介绍了java实现列表、集合与数组之间转化的方法,涉及java中列表、集合与数组相互转换的技巧,非常具有实用价值,需要的朋友可以参考下
    2015-03-03
  • SpringBoot3利用AOP实现IP黑名单功能

    SpringBoot3利用AOP实现IP黑名单功能

    在Web应用开发中,控制对特定IP地址的访问权限是一个常见的需求,通过实现IP黑白名单功能,我们可以允许某些IP地址访问应用,同时拒绝其他IP地址的访问,本文将详细介绍SpringBoot3利用AOP实现IP黑名单功能,并附上相应的代码片段,需要的朋友可以参考下
    2024-09-09
  • Spring Boot 实现Redis分布式锁原理

    Spring Boot 实现Redis分布式锁原理

    这篇文章主要介绍了Spring Boot实现Redis分布式锁原理,文章围绕主题展开详细的内容介绍,具有一定的参考价值,需要的朋友可以参考一下
    2022-08-08

最新评论