电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

Java鏈表中元素刪除的實現方法詳解【只刪除一個元素情況】

瀏覽:121日期:2022-09-04 13:14:36

本文實例講述了Java鏈表中元素刪除的實現方法。分享給大家供大家參考,具體如下:

該部分與上一節是息息相關的,關于如何在鏈表中刪除元素,我們一步一步來分析:

一、圖示刪除邏輯

假設我們需要在鏈表中刪除索引為2位置的元素,此時鏈表結構為:

Java鏈表中元素刪除的實現方法詳解【只刪除一個元素情況】

若要刪除索引為2位置的元素,需要獲取索引為2位置的元素之前的前置節點(此時為索引為1的位置的元素),因此我們需要設計一個變量prev來記錄前置節點。

1.初始時變量prev指向虛擬頭結點dummyHead:

Java鏈表中元素刪除的實現方法詳解【只刪除一個元素情況】

2.尋找到前置節點位置,(對于該例子前置節點為索引為1的位置的元素)。

Java鏈表中元素刪除的實現方法詳解【只刪除一個元素情況】

則此時prev記錄的next即為需要刪除的節點,記為delNode變量。

Java鏈表中元素刪除的實現方法詳解【只刪除一個元素情況】

3.刪除操作

第一步:將prev的next指向delNode的next,如圖:

Java鏈表中元素刪除的實現方法詳解【只刪除一個元素情況】

代碼為:

prev.next=delNode.next;

第二步:為了java能夠回收這個被刪除的空間,我們手動讓需要被刪除的節點從鏈表中脫離開來,也就是delNode的next變為null。

Java鏈表中元素刪除的實現方法詳解【只刪除一個元素情況】

代碼為:

delNode.next=null;二、代碼實現刪除邏輯

2.1 從鏈表刪除第index(0-based)個位置的元素 ,返回刪除的元素

首先,初始化當前前置節點指向虛擬頭結點,然后遍歷尋找到需要被刪除節點的前置節點,最后執行刪除邏輯。

//從鏈表刪除第index(0-based)個位置的元素 ,返回刪除的元素 (實際不常用,練習用) public E remove(int index) { if (index < 0 || index >= size) { throw new IllegalArgumentException('remove failed,Illegal index'); } //獲取虛擬頭節點 Node<E> prev = dummyHead; for (int i = 0; i < index; i++) { //獲取到刪除元素之前節點 prev = prev.next; } Node<E> retNode = prev.next;//被刪除的元素 prev.next = retNode.next; retNode.next = null; size--; return retNode.e; }

2.2 從鏈表中刪除第一個元素,返回刪除的元素

基于remove(int index)方法實現該方法:

//從鏈表中刪除第一個元素,返回刪除的元素 public E removeFirst() { return remove(0); }

2.3 從鏈表中刪除最后一個元素,返回刪除的元素

基于remove(int index)方法實現該方法:

//從鏈表中刪除最后一個元素,返回刪除的元素 public E removeLast() { return remove(size - 1); }三、測試刪除邏輯

基于上一節的測試代碼,我們新增刪除邏輯代碼,此時貼出全部測試代碼:

package LinkedList;public class TestMain { public static void main(String[] args) { LinkedList<Integer> linkedList = new LinkedList<Integer>(); System.out.println('============在鏈表頭部添加============'); for (int i = 0; i < 5; i++) { linkedList.addFirst(i); System.out.println(linkedList); } System.out.println('============修改鏈表============'); linkedList.set(2, 666); System.out.println(linkedList); System.out.println('============刪除鏈表中666節點============'); linkedList.remove(2); System.out.println(linkedList); }}

結果為:

Java鏈表中元素刪除的實現方法詳解【只刪除一個元素情況】

四、鏈表的時間復雜度分析

4.1 添加操作的時間復雜度

(1)在鏈表尾部添加(addLast())需要從頭遍歷,時間復雜度為O(n);

(2)在鏈表頭部添加(addFirst()),時間復雜度為O(1);

(3)在鏈表任意位置添加(add(int index,E e)),平均情況下為O(n/2)=O(n);

Java鏈表中元素刪除的實現方法詳解【只刪除一個元素情況】

4.2 刪除操作的時間復雜度

(1)刪除鏈表最后一個元素(removeLast()),需要遍歷找到最后元素的前一個元素,故時間復雜度為O(n);

(2)刪除鏈表的第一個元素(removeFirst()),時間復雜度為O(1)

(3)刪除鏈表中任意位置節點(remove(index)),平均情況下時間復雜度為O(n/2)=O(n);

Java鏈表中元素刪除的實現方法詳解【只刪除一個元素情況】

4.3 修改操作

由于鏈表不支持隨機訪問,需要從頭開始尋找直到找到需要修改的節點,故時間復雜度為O(n)

Java鏈表中元素刪除的實現方法詳解【只刪除一個元素情況】

4.4 查找操作

由于鏈表不支持隨機訪問,需要從頭開始尋找直到找到需要的節點,故時間復雜度為O(n)

Java鏈表中元素刪除的實現方法詳解【只刪除一個元素情況】

從上不難看出,關于鏈表的添加操作、刪除操作、修改操作、查找操作的時間復雜度均為O(n),看到這個頓時心涼了半截,這個還搞個mao,還不如數組呢,其實確實是這樣的,因為對于數組來說,只要有索引即可實現快速訪問。但是對于鏈表來說,我們如果只對鏈表頭進行添加操作、刪除操作、查找操作那么它的的時間復雜度為均O(1),這時和數組是一樣,是動態的,不會大量的浪費內存空間,這就是它的優勢,由于鏈表是最基礎的動態數據結構,在此基礎上將會有更多關于鏈表的應用。

Java鏈表中元素刪除的實現方法詳解【只刪除一個元素情況】

關于本小節,若您覺得還行、還過得去,麻煩給個推薦吧,謝謝!!

關于鏈表的源碼 https://github.com/FelixBin/dataStructure/tree/master/src/LinkedList

更多關于java算法相關內容感興趣的讀者可查看本站專題:《Java數據結構與算法教程》、《Java操作DOM節點技巧總結》、《Java文件與目錄操作技巧匯總》和《Java緩存操作技巧匯總》

希望本文所述對大家java程序設計有所幫助。

標簽: Java
相關文章:
主站蜘蛛池模板: 箱式破碎机_移动方箱式破碎机/价格/厂家_【华盛铭重工】 | 油罐车_加油机_加油卷盘_加油机卷盘_罐车人孔盖_各类球阀_海底阀等车用配件厂家-湖北华特专用设备有限公司 | 天津仓库出租网-天津电商仓库-天津云仓一件代发-【博程云仓】 | 闭端端子|弹簧螺式接线头|防水接线头|插线式接线头|端子台|电源线扣+护线套|印刷电路板型端子台|金笔电子代理商-上海拓胜电气有限公司 | 压装机-卧式轴承轮轴数控伺服压装机厂家[铭泽机械] | pbootcms网站模板|织梦模板|网站源码|jquery建站特效-html5模板网 | 全自动固相萃取仪_高通量真空平行浓缩仪-勤业永为 | ALC墙板_ALC轻质隔墙板_隔音防火墙板_轻质隔墙材料-湖北博悦佳 | LOGO设计_品牌设计_VI设计 - 特创易 | 众品家具网-家具品牌招商_家具代理加盟_家具门户的首选网络媒体。 | 潍坊青州古城旅游景点攻略_青州酒店美食推荐-青州旅游网 | 低浓度恒温恒湿称量系统,强光光照培养箱-上海三腾仪器有限公司 | 蜘蛛车-登高车-高空作业平台-高空作业车-曲臂剪叉式升降机租赁-重庆海克斯公司 | 博客-悦享汽车品质生活| 江苏全风,高压风机,全风环保风机,全风环形高压风机,防爆高压风机厂家-江苏全风环保科技有限公司(官网) | 生物除臭剂-除味剂-植物-污水除臭剂厂家-携葵环保有限公司 | 铝箔袋,铝箔袋厂家,东莞铝箔袋,防静电铝箔袋,防静电屏蔽袋,防静电真空袋,真空袋-东莞铭晋让您的产品与众不同 | 注塑模具_塑料模具_塑胶模具_范仕达【官网】_东莞模具设计与制造加工厂家 | 江西高职单独招生-江西单招考试-江西高职单招网 | 小型数控车床-数控车床厂家-双头数控车床 | 高压贴片电容|贴片安规电容|三端滤波器|风华电容代理南京南山 | 隐形纱窗|防护纱窗|金刚网防盗纱窗|韦柏纱窗|上海青木装潢制品有限公司|纱窗国标起草单位 | 绿萝净除甲醛|深圳除甲醛公司|测甲醛怎么收费|培训机构|电影院|办公室|车内|室内除甲醛案例|原理|方法|价格立马咨询 | 上海租奔驰_上海租商务车_上海租车网-矢昂汽车服务公司 | 隧道风机_DWEX边墙风机_SDS射流风机-绍兴市上虞科瑞风机有限公司 | 深圳活动策划公司|庆典策划|专业公关活动策划|深圳艺典文化传媒 重庆中专|职高|技校招生-重庆中专招生网 | 青州开防盗门锁-配汽车芯片钥匙-保险箱钥匙-吉祥修锁店 | 车间除尘设备,VOCs废气处理,工业涂装流水线,伸缩式喷漆房,自动喷砂房,沸石转轮浓缩吸附,机器人喷粉线-山东创杰智慧 | 安全阀_弹簧式安全阀_美标安全阀_工业冷冻安全阀厂家-中国·阿司米阀门有限公司 | 土壤有机碳消解器-石油|表层油类分析采水器-青岛溯源环保设备有限公司 | 开云(中国)Kaiyun·官方网站-登录入口 | 专业的压球机生产线及解决方案厂家-河南腾达机械厂 | lcd条形屏-液晶长条屏-户外广告屏-条形智能显示屏-深圳市条形智能电子有限公司 | 优秀的临床医学知识库,临床知识库,医疗知识库,满足电子病历四级要求,免费试用 | 量子管通环-自清洗过滤器-全自动反冲洗过滤器-北京罗伦过滤技术集团有限公司 | 河南道路标志牌_交通路标牌_交通标志牌厂家-郑州路畅交通 | LNG鹤管_内浮盘价格,上装鹤管,装车撬厂家-连云港赛威特机械 | 化妆品加工厂-化妆品加工-化妆品代加工-面膜加工-广东欧泉生化科技有限公司 | 物流之家新闻网-最新物流新闻|物流资讯|物流政策|物流网-匡匡奈斯物流科技 | 石油/泥浆/不锈钢防腐/砂泵/抽砂泵/砂砾泵/吸砂泵/压滤机泵 - 专业石油环保专用泵厂家 | 【黄页88网】-B2B电子商务平台,b2b平台免费发布信息网 |