速度了解神奇的索引操作 | 带你学《Java面向对象编程》之九十三

简介: 本节带领读者实现了根据索引取数据和修改数据的操作,并对这些操作进行了简单的复杂度分析。

上一篇:教你实现链表判空与取值方法 | 带你学《Java面向对象编程》之九十二
【本节目标】
通过阅读本节内容,你将学会在链表中通过上一节中提到的foot属性实现对指定位置数据进行取值和改值的操作。

根据索引取得数据:public E get(int index)

链表可以像数组一样进行处理,所以也应该可以像数组一样进行索引数据的获取,在这样的情况下就可以继续利用递归的形式来完成。

image.png
图一 依据索引获取数据

1、在ILink接口中追加新的方法

public E get(int index) ;   //根据索引获取数据

2、在Node类里面追加有根据索引获取数据的处理

public E getNode(int index) {
     if (LinkImpl.this.foot ++ == index) {       //索引相同
         return this.data ;    //返回当前数据
     }else {
         return this.next.getNode(index) ;
     }
}

3、在LinkImpl子类里面定义数据获取的实现

 public E get(int index) {
     if (index >= this.count) {    //索引应该在指定的范围之内
         return null ;
     }    //索引数据的获取应该由Node类完成
        this.foot = 0 ;   //重置索引的下标
        return this.root.getNode(index) ;
}

image.png
图二 执行结果图

这一特点和数组是很相似的,但是需要注意的是,数组获取一个数据的时间复杂度为1,而链表获取数据的时间复杂度为n。

修改指定索引数据:public void set(int index, E data)

现在已经可以根据索引来获取指定的索引数据了,但是既然可以获取数据,那么也可以进行数据的修改。
1、在ILink接口中追加有新的方法

public void set(int index,E data) ;    //修改索引数据

2、在Node类之中应该提供有数据修改的处理支持

public void setNode(int index,E data) {
    if (LinkImpl.this.foot ++ == index) {       //索引相同
       this.data = data ;    //修改数据
    }else {
       this.next.setNode(index,data) ;
    }
}      

3、在LinkImpl子类里面进行方法的覆写。

public void set(int index,E data) {
    if (index >= this.count) {    //索引应该在指定的范围之内
        return  ;     //方法结束
    }    //索引数据的获取应该由Node类完成
        this.foot = 0 ;   //重置索引的下标
        this.root.setNode(index,data) ;  //修改数据
}  

image.png
图三 执行结果二

这种操作的时间复杂度也是n,因为依然需要进行数据的遍历处理。

想学习更多的Java的课程吗?从小白到大神,从入门到精通,更多精彩不容错过!免费为您提供更多的学习资源。
本内容视频来源于阿里云大学

下一篇:链表数据“暗杀记” | 带你学《Java面向对象编程》之九十四
更多Java面向对象编程文章查看此处

相关文章
|
9月前
|
Java
Java 面向对象编程的三大法宝:封装、继承与多态
本文介绍了Java面向对象编程中的三大核心概念:封装、继承和多态。
466 15
|
9月前
|
Java 数据安全/隐私保护 开发者
【潜意识Java】深入理解 Java 面向对象编程(OOP)
本文介绍了Java中的面向对象编程(OOP)核心概念,包括封装、继承、多态和抽象。封装通过访问控制保护数据,提高安全性;继承支持代码复用,减少冗余;多态实现灵活的行为调用;抽象则隐藏细节,简化接口设计。掌握这些概念有助于编写高效、灵活且易于维护的代码。文章通过实例详细讲解了每个概念在Java中的应用,并总结了它们的优势。
360 3
|
11月前
|
关系型数据库 MySQL Java
MySQL索引优化与Java应用实践
【11月更文挑战第25天】在大数据量和高并发的业务场景下,MySQL数据库的索引优化是提升查询性能的关键。本文将深入探讨MySQL索引的多种类型、优化策略及其在Java应用中的实践,通过历史背景、业务场景、底层原理的介绍,并结合Java示例代码,帮助Java架构师更好地理解并应用这些技术。
269 2
|
11月前
|
Java 开发者
Java 面向对象编程
总之,Java 的面向对象编程为开发者提供了一种有效的编程范式,帮助他们构建出高质量、可维护的软件系统。理解和掌握面向对象的概念和原则是成为优秀 Java 开发者的重要基础。
304 63
|
Java 开发者
那些年,我们一同踏入Java编程的大门,多态,这个充满魔法的名字,曾无数次点亮我们探索面向对象编程的热情。
那些年,我们一同踏入Java编程的大门,多态,这个充满魔法的名字,曾无数次点亮我们探索面向对象编程的热情。
103 5
|
Java 开发者
在Java面向对象编程的广阔海洋中,多态犹如一股深邃的潜流,它推动着代码从单一走向多元,从僵化迈向灵活。
在Java面向对象编程的广阔海洋中,多态犹如一股深邃的潜流,它推动着代码从单一走向多元,从僵化迈向灵活。
95 7
|
Java 程序员
Java中的继承和多态:理解面向对象编程的核心概念
【8月更文挑战第22天】在Java的世界中,继承和多态不仅仅是编程技巧,它们是构建可维护、可扩展软件架构的基石。通过本文,我们将深入探讨这两个概念,并揭示它们如何共同作用于面向对象编程(OOP)的实践之中。你将了解继承如何简化代码重用,以及多态如何为程序提供灵活性和扩展性。让我们启程,探索Java语言中这些强大特性的秘密。
|
Java 程序员 开发者
Java的面向对象编程:从基础到深入
【8月更文挑战第21天】在本文中,我们将探讨Java的面向对象编程(OOP)的核心概念,包括类、对象、继承、多态和封装。我们将通过实例和比喻,以通俗易懂的方式,深入理解这些概念的内涵和意义,以及它们如何影响我们的编程思维和实践。无论你是初学者还是有经验的开发者,这篇文章都将帮助你更深入地理解Java的OOP,并启发你思考如何在你的项目中应用这些概念。
|
Java API 数据中心
百炼平台Java 集成API上传文档到数据中心并添加索引
本文主要演示阿里云百炼产品,如何通过API实现数据中心文档的上传和索引的添加。
805 4
|
自然语言处理 Java 索引
ElasticSearch 实现分词全文检索 - Java SpringBoot ES 索引操作
ElasticSearch 实现分词全文检索 - Java SpringBoot ES 索引操作
154 0