链表—向链表中添加元素
2019-07-15 本文已影响0人
尤奇勤_三月
冰冻非一日之寒
添加剂元素之前
data:image/s3,"s3://crabby-images/6a52b/6a52be97b908dc30cfc7f6099352002291ab257c" alt=""
向链表头部添加元素:
现在有一个链表,头部结点,为head,假设要将结点node添加到链表首部
data:image/s3,"s3://crabby-images/8ca72/8ca727c1b630203e59103b89eb33a8b81b3094dd" alt=""
直接将node.next指向head,然后改变链表首部为node
data:image/s3,"s3://crabby-images/2269b/2269b4ce04fe97be50e417ced559252b0f7a1f68" alt=""
这样,就完成了node插入到链表的首部了。
data:image/s3,"s3://crabby-images/1a8aa/1a8aaa9893dd5abf4d07dfcb0f8d2b7f35e34f2a" alt=""
java实现
data:image/s3,"s3://crabby-images/1c944/1c94439c780e820be30c13b3508450460d41eb82" alt=""
向index位置处添加元素:
假设向结点为2处添加结点node
data:image/s3,"s3://crabby-images/52284/52284c2e096a12762aac5829e9ce685a26dc7d31" alt=""
找到2结点处的前一个结点pre,即1结点,并node.next = pre.next
data:image/s3,"s3://crabby-images/66f53/66f53fc97f76ae7ae09d6b5fe5ac10e075b5ab1b" alt=""
然后,pre.next = node
data:image/s3,"s3://crabby-images/fea9b/fea9b9a85a772c632e55a14f847c5be064a082f5" alt=""
这样,就完成了结点node的添加。
这个过程的关键,是找到要添加结点的前一个结点。
data:image/s3,"s3://crabby-images/fcc68/fcc6868a7973c42ca7f28e037b018e581b1c26ec" alt=""
另外,
node.next = pre.next;pre.next = node这两句代码顺序是不能颠倒的。
注意,假如要添加的地方是第一个结点处,就不能使用这种方法了,因为第一个结点是没有前一个结点的。
java实现
data:image/s3,"s3://crabby-images/2f0a1/2f0a10d5d80a82ebfcd2a1f9c45887046ee3bcca" alt=""
向链表尾部添加元素:
直接调用add()函数即可
data:image/s3,"s3://crabby-images/01c0e/01c0ec2685f140449a93d0923204341eb153d7df" alt=""