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

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

Java鏈表中添加元素的原理與實現方法詳解

瀏覽:116日期:2022-09-04 13:24:43

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

1.鏈表中頭節點的引入

1.1基本的鏈表結構:

Java鏈表中添加元素的原理與實現方法詳解

1.2對于鏈表來說,若想訪問鏈表中每個節點則需要把鏈表的頭存起來,假如鏈表的頭節點為head,指向鏈表中第一個節點,如圖:

Java鏈表中添加元素的原理與實現方法詳解

1.3使用代碼表示此時的鏈表

//定義頭節點 private Node head; //節點個數 private int size; //無參數構造函數 public LinkedList() { head = null; size = 0; } //獲取鏈表中的元素個數 public int getSize() { return size; } //返回鏈表是否為空 public boolean isEmpty() { return size == 0; } 2.在鏈表頭添加元素

2.1初始時,假設鏈表如下:

Java鏈表中添加元素的原理與實現方法詳解

2.2 如在鏈表頭添加一個666元素則需要先將666放進一個節點里,在節點里存入這個元素以及相應的next。

Java鏈表中添加元素的原理與實現方法詳解

操作如下:

第一步:現將666這個節點(node)的next指向head,代碼如下:

node.next=head

圖示為:

Java鏈表中添加元素的原理與實現方法詳解

第二步:然后再將head指向新的節點666

head=node

圖示為:

Java鏈表中添加元素的原理與實現方法詳解

通過第一步、第二步,我們就成功將新節點添加到頭節上。此時node這個變量也就結束了此輪的工作,結果變為:

Java鏈表中添加元素的原理與實現方法詳解

2.3 在鏈表頭添加新元素的相關代碼

//在鏈表頭添加新的元素e public void addFirst(E e) { Node node = new Node(e); node.next = head; head = node; size++; }

等同于:

//在鏈表頭添加新的元素e public void addFirst(E e) { head = new Node(e, head); size++; }

2.4 在鏈表中間添加元素

假設初始鏈表為:

Java鏈表中添加元素的原理與實現方法詳解

假設我們需要在索引為2的位置添加元素666(此時的索引為2只是用來說明我們此時需要操作的位置,并不是真正的索引意思)

操作步驟:

1):創建出666這個節點

Java鏈表中添加元素的原理與實現方法詳解

2):使用一個變量prev來標識在需要插入節點的地方的前一個節點,初始時prev和頭節點head是相同的。

Java鏈表中添加元素的原理與實現方法詳解

對于此處我們需要在索引為2的位置插入新元素,我們只需要找到索引為2的前一個位置(索引為1),然后把prev指向索引為1節點即可。

Java鏈表中添加元素的原理與實現方法詳解

3):進行元素添加操作

第一步:先將node的next指向prev的下一個節點元素

node.next=prev.next

Java鏈表中添加元素的原理與實現方法詳解

第二步:再將prev的next指向node

prev.next=node

Java鏈表中添加元素的原理與實現方法詳解

通過第一步、第二步即可將新元素插入到索引為2的地方。

從上不難看出,對于在鏈表中添加元素關鍵是找到要添加的節點的前一個節點,因此對于在索引為0的節點添加元素就需要單獨處理。

關于在鏈表中間添加元素的代碼:

//在鏈表的index(0--based)的位置添加新的元素e (實際不常用,練習用) public void add(int index, E e) { if (index < 0 || index > size) { throw new IllegalArgumentException('位置不合法'); } //對于頭節點的特殊處理 if (index == 0) { addFirst(e); } else { Node prev = head; for (int i = 0; i < index - 1; i++) {//獲取到需要添加元素位置的前一個元素prev = prev.next; } Node node = new Node(e); node.next = prev.next; prev.next = node; size++; } }

此時代碼等同于:

//在鏈表的index(0--based)的位置添加新的元素e (時間不常用,練習用) public void add(int index, E e) { if (index < 0 || index > size) { throw new IllegalArgumentException('位置不合法'); } //對于頭節點的特殊處理 if (index == 0) { addFirst(e); } else { Node prev = head; for (int i = 0; i < index - 1; i++) {//獲取到需要添加元素位置的前一個元素prev = prev.next; }// Node node = new Node(e);// node.next = prev.next;// prev.next = node; prev.next=new Node(e,prev.next); size++; } }3.在鏈表尾部添加元素

這里復用上述的add()方法

//在鏈表末尾添加新的元素 public void addLast(E e){ add(size,e); }

本小節完整代碼:

package LinkedList;public class LinkedList<E> { //將Node節點設計成私有的類中類 private class Node<E> { public E e; public Node next; //兩個參數的構造函數 public Node(E e, Node next) { this.e = e; this.next = next; } //一個參數的構造函數 public Node(E e) { this.e = e; this.next = null; } //無參構造函數 public Node() { this(null, null); } @Override public String toString() { return e.toString(); } } //定義頭節點 private Node head; //節點個數 private int size; //無參數構造函數 public LinkedList() { head = null; size = 0; } //獲取鏈表中的元素個數 public int getSize() { return size; } //返回鏈表是否為空 public boolean isEmpty() { return size == 0; } //在鏈表頭添加新的元素e public void addFirst(E e) { head = new Node(e, head); size++; } //在鏈表的index(0--based)的位置添加新的元素e (實際不常用,練習用) public void add(int index, E e) { if (index < 0 || index > size) { throw new IllegalArgumentException('位置不合法'); } //對于頭節點的特殊處理 if (index == 0) { addFirst(e); } else { Node prev = head; for (int i = 0; i < index - 1; i++) {//獲取到需要添加元素位置的前一個元素prev = prev.next; }// Node node = new Node(e);// node.next = prev.next;// prev.next = node; prev.next=new Node(e,prev.next); size++; } } //在鏈表末尾添加新的元素 public void addLast(E e){ add(size,e); }}

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

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

標簽: Java
相關文章:
主站蜘蛛池模板: 焊管生产线_焊管机组_轧辊模具_焊管设备_焊管设备厂家_石家庄翔昱机械 | UV固化机_UVLED光固化机_UV干燥机生产厂家-上海冠顶公司专业生产UV固化机设备 | 电镀整流器_微弧氧化电源_高频电解电源_微弧氧化设备厂家_深圳开瑞节能 | 玻璃钢型材-玻璃钢风管-玻璃钢管道,生产厂家-[江苏欧升玻璃钢制造有限公司] | 百度网站优化,关键词排名,SEO优化-搜索引擎营销推广 | PVC地板|PVC塑胶地板|PVC地板厂家|地板胶|防静电地板-无锡腾方装饰材料有限公司-咨询热线:4008-798-128 | 武汉森源蓝天环境科技工程有限公司-为环境污染治理提供协同解决方案 | 颗粒机,颗粒机组,木屑颗粒机-济南劲能机械有限公司 | 嘉兴恒升声级计-湖南衡仪声级计-杭州爱华多功能声级计-上海邦沃仪器设备有限公司 | 多物理场仿真软件_电磁仿真软件_EDA多物理场仿真软件 - 裕兴木兰 | 短信营销平台_短信群发平台_106短信发送平台-河南路尚 | 管理会计网-PCMA初级管理会计,中级管理会计考试网站 | 液氮罐(生物液氮罐)百科-无锡爱思科| ★塑料拖链__工程拖链__电缆拖链__钢制拖链 - 【上海闵彬】 | 螺钉式热电偶_便携式温度传感器_压簧式热电偶|无锡联泰仪表有限公司|首页 | 考试试题_试卷及答案_诗词单词成语 - 优易学 | 【直乐】河北石家庄脊柱侧弯医院_治疗椎间盘突出哪家医院好_骨科脊柱外科专业医院_治疗抽动症/关节病骨伤权威医院|排行-直乐矫形中医医院 | 慈溪麦田广告公司,提供慈溪广告设计。 | 诗词大全-古诗名句 - 古诗词赏析 | 热回收盐水机组-反应釜冷水机组-高低温冷水机组-北京蓝海神骏科技有限公司 | 广州展台特装搭建商|特装展位设计搭建|展会特装搭建|特装展台制作设计|展览特装公司 | 全自动五线打端沾锡机,全自动裁线剥皮双头沾锡机,全自动尼龙扎带机-东莞市海文能机械设备有限公司 | 必胜高考网_全国高考备考和志愿填报信息平台 | 暖气片十大品牌厂家_铜铝复合暖气片厂家_暖气片什么牌子好_欣鑫达散热器 | 百度关键词优化_网站优化_SEO价格 - 云无限好排名 | 不发火防静电金属骨料_无机磨石_水泥自流平_修补砂浆厂家「圣威特」 | 番茄畅听邀请码怎么输入 - Dianw8.com| 超声骨密度仪-骨密度检测仪-经颅多普勒-tcd仪_南京科进实业有限公司 | 硅胶制品-硅橡胶制品-东莞硅胶制品厂家-广东帝博科技有限公司 | 整车VOC采样环境舱-甲醛VOC预处理舱-多舱法VOC检测环境仓-上海科绿特科技仪器有限公司 | PE拉伸缠绕膜,拉伸缠绕膜厂家,纳米缠绕膜-山东凯祥包装 | 振动台-振动试验台-振动冲击台-广东剑乔试验设备有限公司 | 不锈钢/气体/液体玻璃转子流量计(防腐,选型,规格)-常州天晟热工仪表有限公司【官网】 | 花纹铝板,合金铝卷板,阴极铝板-济南恒诚铝业有限公司 | 物流之家新闻网-最新物流新闻|物流资讯|物流政策|物流网-匡匡奈斯物流科技 | 鹤壁创新仪器公司-全自动量热仪,定硫仪,煤炭测硫仪,灰熔点测定仪,快速自动测氢仪,工业分析仪,煤质化验仪器 | 工作心得_读书心得_学习心得_找心得体会范文就上学道文库 | 骨龄仪_骨龄检测仪_儿童骨龄测试仪_品牌生产厂家【品源医疗】 | EFM 022静电场测试仪-套帽式风量计-静电平板监测器-上海民仪电子有限公司 | 民用音响-拉杆音响-家用音响-ktv专用音响-万昌科技 | 手板-手板模型-手板厂-手板加工-生产厂家,[东莞创域模型] |