我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Java数组高频考点分析讲解

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

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 数组内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Java数组高频考点分析讲解

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Java数组高频考点实例分析

这篇文章主要介绍“Java数组高频考点实例分析”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Java数组高频考点实例分析”文章能帮助大家解决问题。1、数组理论基础数组是存放在连续内存空间上的相同类型
2023-06-29

Java高频面试题之海量数据处理分析

海量信息处理日益成为当前程序员笔试面试中一个新的亮点。硬件扩容是难满足海量数据处理需要的,如何利用现有条件进行海量信息处理?本文就来为大家解答一下
2022-11-13

掌握系统集成项目管理工程师考试高频考点,轻松拿分!(系统集成项目管理工程师考试高频考点解析与应试技巧)

系统集成项目管理工程师考试高频考点解析项目管理基础:项目生命周期、范围、时间、成本、质量、风险等管理知识。系统集成特有知识:系统集成概念、原则、方法、工具和风险管理。高频考点解析:项目范围管理:项目范围说明书、范围管理计划、变更控制。时间管理:工作分解结构、进度计划、关键路径分析。成本管理:成本估算方法、预算编制、成本控制。项目质量管理:质量计划、控制措施、审计和持续改进。系统集成项目管理:规划、设计、实施、测试和验收。应试技巧:理解概念、熟记公式、练习案例、合理分配时间、稳健作答、复习总结、保持积极心态
掌握系统集成项目管理工程师考试高频考点,轻松拿分!(系统集成项目管理工程师考试高频考点解析与应试技巧)
2024-04-02

Kotlin中Lambda表达式与高阶函数使用分析讲解

lambda本质上是可以传递给函数的一小段代码,Kotlin与Java中的Lambda有一定的区别,除了对lambda的全面支持外,还有内联函数等简洁高效的特性。下面我们来仔细看一下
2022-12-08

2021下半年信息系统管理工程师高频考点:信息系统分析

  为帮助大家备考2021下半年信息系统管理工程师考试,今天编程学习网小编整理了信息系统管理工程师高频考点:信息系统分析,希望对大家备考会有帮助。  第12章 信息系统分析  根据对历年的考试真题进行分析,本章要求考生掌握以下几个方面的知识:  (1)结构化分析方法:数据流图、数据字典。  (2)UML:关系、图  >
2021下半年信息系统管理工程师高频考点:信息系统分析
2024-04-19

精准掌握系统集成项目管理工程师考试要点,轻松拿高分!(系统集成项目管理工程师考试要点解析与应试技巧)

精准掌握核心知识领域,涵盖项目集成、范围、时间、成本等方面。采用系统复习、掌握应试技巧,如熟悉大纲、利用答题技巧和考试辅助工具。把握时间分配,注重质量、避免出错。制定复习计划,加入备考小组,通过模拟考试演练。保持冷静、沉着,相信自己实力,高分通关不是梦。
精准掌握系统集成项目管理工程师考试要点,轻松拿高分!(系统集成项目管理工程师考试要点解析与应试技巧)
2024-04-02

【华为OD机试真题】15、数组拼接 | 机试真题+思路参考+代码解析(C语言、C++、Java、Py、JS)

文章目录 一、题目 ?题目描述 ?输入输出 ?样例1 ?样例2 二、代码与思路参考 ?C语言思路
2023-08-24

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录