双向链表的操作分析和实现
(1)单向链表和双向链表的区别
单向链表只能往一个方向进行查找,而双向链表可以向前或向后查找
单向链表想要删除节点必须找到对应节点的前一个节点,而双向链表可以进行自我删除
(2)操作分析(基于前篇单向链表)
![](https://i-blog.csdnimg.cn/blog_migrate/ffd2d715023c21a58ca10befbb3609d3.png)
1)遍历:与单向链表相同,但是既可以向前也可以向后进行查找
2)增加到链表末尾:与单向链表相比需要将新增加的节点的pre指向原来的最后一个元素,即新节点.pre=temp,temp.next=新节点
3)增加到指定位置:找到链表的位置,然后新节点.next=temp.next;新节点.pre=temp;temp.next=新节点
4)修改:与单向链表相同
5)删除:双向链表可以实现自删除,无需找到前一个节点,直接找到这个节点temp,temp.next.pre=temp.pre;temp.pre.next=temp.next
代码实现
class DoubleLinkedList{
private HeroNode2 head = new HeroNode2(0,"","");
public HeroNode2 getHead() {
return head;
}
public void list() {
if (head.next == null) {
System.out.println("链表为空");
return;
}
HeroNode2 temp = head.next;
while (true) {
if (temp == null) {
break;
}
System.out.println(temp);
temp = temp.next;
}
}
public void add(HeroNode2 heroNode) {
HeroNode2 temp = head;
while (true) {
if (temp.next == null) {
break;
}
temp = temp.next;
}
//此时temp指向链表最后一个元素,将要插入的数据放到temp之后
temp.next = heroNode;
heroNode.pre = temp;
}
public void addByOrder(HeroNode2 heroNode2){
HeroNode2 temp = head;
boolean flag = false;//判断是否存在
while(true){
if (temp.next ==null){
break;
}
if (temp.next.no > heroNode2.no){
break;
}else if(temp.next.no == heroNode2.no){
flag =true;
break;
}
temp = temp.next;
}
if(flag){
System.out.println("已经存在无法添加");
}else{
heroNode2.next = temp.next;
heroNode2.pre = temp;
temp.next = heroNode2;
}
}
public void update(HeroNode2 newHeroNode) {
HeroNode2 temp = head.next;
boolean flag = false; //标记是否找到
if (head.next ==null){
System.out.println("链表为空");
return;
}
while(true){
if(temp == null){
break;
}
if(temp.no == newHeroNode.no){
flag = true;
break;
}
temp = temp.next;
}
if(flag){
temp.nickname = newHeroNode.nickname;
temp.name = newHeroNode.name;
}else{
System.out.println("未找到要修改的数据");
}
}
public void delete(int no){
HeroNode2 temp = head.next;
boolean flag = false;
if(head.next == null){
System.out.println("链表为空");
return;
}
while(true){
if(temp == null){
break;
}
if(temp.no == no){
flag = true;
break;
}
temp = temp.next;
}
if(flag){
if(temp.next != null){
temp.next.pre = temp.pre;
}
temp.pre.next = temp.next;
}else{
System.out.printf("未找到编号为%d的英雄\n",no);
}
}
}
class HeroNode2 {
public int no;
public String name;
public String nickname;
public HeroNode2 next;
public HeroNode2 pre;
public HeroNode2(int no, String name, String nickname) {
this.no = no;
this.name = name;
this.nickname = nickname;
}
@Override
public String toString() {
return "HeroNode{" +
"no=" + no +
", name='" + name + '\'' +
", nickname='" + nickname + '\'' +
'}';
}
}