直接上代码

//节点
class HeroNodeD{
int no;
String name;
String nickName;
HeroNodeD pre;//前一节点
HeroNodeD next;//后一节点 public HeroNodeD(int no, String name, String nickName) {
this.no = no;
this.name = name;
this.nickName = nickName;
} @Override
public String toString() {
return "HeroNodeD{" +
"no=" + no +
", name='" + name + '\'' +
", nickName='" + nickName + '\'' +
'}';
}
}

双向链表:

//双向链表
class DoublleLinkList{
public HeroNodeD head = new HeroNodeD(0,"",""); public void setHead(HeroNodeD head) {
this.head = head;
} //0, 获取头结点
public HeroNodeD getHead(){
return head;
}
//1, 获取尾结点
public HeroNodeD getLastNode(){
HeroNodeD temp = head;
while(true){
if(temp.next == null){
break;//尾节点
}
temp = temp.next;
}
return temp;
}
//2, 添加(添加节点到链表的最后面)
public void add(HeroNodeD node){
HeroNodeD temp = head;
while(true){
if(temp.next == null){
break;//尾节点
}
temp = temp.next;
}
//循环结束后,此时temp就是尾节点
temp.next = node;
node.pre = temp;
}
//3, 添加(根据节点的no(排名)的大小, 有序添加)
public void addByNo(HeroNodeD node){
HeroNodeD temp = head;
while (true) {
if(temp.next == null){
break;//链表尾部就跳出
}
if(temp.next.no > node.no){
break;
}
temp = temp.next;
}
//循环结束, 说明temp的下一节点, 就是node的插入位置
node.next = temp.next;//设置node和 temp.next的后节点
temp.next.pre = node;//设置node和 temp.next的 前节点 node.pre = temp;//设置temp 和 node的 前节点
temp.next = node;//设置temp 和 node的 后节点
}
//4, 双向链表的 遍历,从前向后遍历
public void showBeginToEnd(){
HeroNodeD temp = head;
while(true){
if(temp.next == null){
break;
}
System.out.println(temp);
temp = temp.next;
}
System.out.println(temp);
}
//5:从后向前遍历
public void showEndToBegin(){
//获取尾节点
HeroNodeD temp = getLastNode();
while(true){
if(temp.pre == null){
break;
}
System.out.println(temp);
temp = temp.pre;
}
System.out.println(temp);
}
//6, 链表的长度// 头节点不计入长度
public int length(){
HeroNodeD temp = head;
int count=0;
while(true){
if(temp.next == null){
break;
}
count++;
temp = temp.next;
}
return count;
}
//7, 删除第n个节点
public void delNode(int n){
int count = 0;
boolean flag = false;
HeroNodeD temp = head.next;
while (temp != null) {
count++;
if (count == n) {
flag = true;
break;
}
temp = temp.next;
}
if(flag){
//跳出循环,说明找到这个节点, 删除该节点
temp.pre.next = temp.next;
temp.next.pre = temp.pre;
}else{
System.out.println("不存在这个节点");
} }
//8, 更改某个节点
public void updateNode(int n, HeroNodeD node){
boolean flag = false;
int count = 0;
HeroNodeD temp = head.next;
while (temp != null) {
if(temp.next == null){
break;
}
count++;
if(count == n){
flag = true;
break;
}
temp = temp.next;
} if(flag){
//更换这个节点
temp.pre.next = node;
node.pre = temp.pre; node.next = temp.next;
temp.next.pre = node;
}else{
System.out.println("不存在这个节点");
}
}
}

测试代码:

    public static void main(String[] args){
DoublleLinkList doublelink = new DoublleLinkList();
HeroNodeD node1 = new HeroNodeD(1, "宋江", "及时雨");
HeroNodeD node2 = new HeroNodeD(2, "吴用", "神算子");
HeroNodeD node3 = new HeroNodeD(3, "卢俊义", "玉麒麟");
HeroNodeD node4 = new HeroNodeD(4, "武松", "打老虎");
HeroNodeD node5 = new HeroNodeD(5, "吕财", "打老虎"); doublelink.add(node1);
doublelink.add(node3);
doublelink.addByNo(node2);//有序添加 doublelink.showBeginToEnd();//1-2-3
System.out.println("==========================");
doublelink.showEndToBegin();//3-2-1
System.out.println(doublelink.length());//长度为3 doublelink.delNode(4);//没有这个节点
doublelink.showBeginToEnd();
System.out.println("==========");
doublelink.updateNode(2,node5);//更换第二个节点
doublelink.showBeginToEnd();
}

测试结果:

最新文章

  1. H5 浏览器开发文档
  2. MSLocalDB
  3. 电量检测芯片BQ27510使用心得
  4. SVN在团队项目中的使用技巧:[2]Tag操作
  5. 史上最佳 Mac+PhpStorm+XAMPP+Xdebug 集成开发和断点调试环境的配置
  6. [转载]Windows 7 IIS (HTTP Error 500.21 - Internal Server Error)解决
  7. [旧博客]QQ旋风加速漏洞
  8. git 删除分支和删除文件夹
  9. UML图基本类型
  10. Xcode添加静态库以及编译选项配置常见问题
  11. Python 脚本实现对 Linux 服务器的监控
  12. nodejs基础教程回顾01
  13. SmartSql 入门
  14. 【Paywave】VISA Paywave - ICS category selection
  15. 亲测:LNMP环境下,解决项目缓冲慢、502以及配置https的问题
  16. VMWARE中NAT下获取不到IP
  17. springBoot的事物管理
  18. 基础必备Linux操作
  19. NoHtml
  20. 关于nginx部署vue项目的两个问题

热门文章

  1. C++ STL 思维导图,脑图,树形图。
  2. 什么?这么精髓的View的Measure流程源码全解析,你确定不看看?
  3. IOS Widget(5):小组件刷新机制
  4. ThreadLocal引起的一次线上事故
  5. Django(13)django时区问题
  6. FPS游戏方框透视基本原理
  7. c++逆向分析----返回对象
  8. 转: inline关键字使用
  9. [Java]数据分析--聚类
  10. 一文搞懂spring的常用注解