伪元素在父元素中居中_链表----在链表中添加元素详解

1.1基本的链表结构:

cdfb5083f2f4e34a0d14545ab6605f94.png

1.2对于链表来说,若想访问链表中每个节点则需要把链表的头存起来,假如链表的头节点为head,指向链表中第一个节点,如图:

669f385d7eb11b82e04ba246b9d757b9.png

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初始时,假设链表如下:

5fdee127380c667e232d099f4566486e.png

2.2 如在链表头添加一个666元素则需要先将666放进一个节点里,在节点里存入这个元素以及相应的next。

777e83315ee2b4fca12dc8932d335521.png

操作如下:

第一步:现将666这个节点(node)的next指向head,代码如下:

node.next=head

图示为:

60b8c109aff15eb2f75238d34abed40c.png

第二步:然后再将head指向新的节点666

head=node

图示为:

3501afec07324e72259edcca2b9e6d19.png

通过第一步、第二步,我们就成功将新节点添加到头节上。此时node这个变量也就结束了此轮的工作,结果变为:

e417b018196b8745c91813a5b15023f9.png

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 在链表中间添加元素

假设初始链表为:

b43fcf03f01677dec4d802ba539b01a6.png

假设我们需要在索引为2的位置添加元素666(此时的索引为2只是用来说明我们此时需要操作的位置,并不是真正的索引意思)

操作步骤:

1):创建出666这个节点

0a8f6e716849b7d4db4756d31fc4bfee.png

2):使用一个变量prev来标识在需要插入节点的地方的前一个节点,初始时prev和头节点head是相同的。

c88587e00c6cf07538a66683a63b1ccd.png

对于此处我们需要在索引为2的位置插入新元素,我们只需要找到索引为2的前一个位置(索引为1),然后把prev指向索引为1节点即可。

6bee94d56488f8cb9225495a2c99bd5f.png

3):进行元素添加操作

第一步:先将node的next指向prev的下一个节点元素

node.next=prev.next
e6a6be1816b31d9c07e0b656946d0301.png

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

prev.next=node
4ea68845a4ed5e66061372cd67a447e1.png

通过第一步、第二步即可将新元素插入到索引为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); }

本小节完整代码:

 1 package LinkedList; 2  3 public class LinkedList { 4 //将Node节点设计成私有的类中类 5 private class Node { 6 public E e; 7 public Node next; 8  9 10 //两个参数的构造函数11 12 public Node(E e, Node next) {13 this.e = e;14 this.next = next;15 }16 17 //一个参数的构造函数18 public Node(E e) {19 this.e = e;20 this.next = null;21 }22 23 //无参构造函数24 public Node() {25 this(null, null);26 }27 28 @Override29 public String toString() {30 return e.toString();31 }32 }33 34 //定义头节点35 private Node head;36 37 //节点个数38 private int size;39 40 41 //无参数构造函数42 public LinkedList() {43 head = null;44 size = 0;45 }46 47 //获取链表中的元素个数48 public int getSize() {49 return size;50 }51 52 //返回链表是否为空53 public boolean isEmpty() {54 return size == 0;55 }56 57 58 //在链表头添加新的元素e59 public void addFirst(E e) {60 head = new Node(e, head);61 size++;62 }63 64 //在链表的index(0--based)的位置添加新的元素e (时间不常用,练习用)65 66 public void add(int index, E e) {67 if (index < 0 || index > size) {68 throw new IllegalArgumentException("位置不合法");69 }70 71 //对于头节点的特殊处理72 if (index == 0) {73 addFirst(e);74 } else {75 Node prev = head;76 for (int i = 0; i < index - 1; i++) {//获取到需要添加元素位置的前一个元素77 prev = prev.next;78 }79 80 // Node node = new Node(e);81 // node.next = prev.next;82 // prev.next = node;83 84 prev.next=new Node(e,prev.next);85 86 size++;87 }88 89 }90 91 //在链表末尾添加新的元素92 public void addLast(E e){93 add(size,e);94 }95 }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值