通过while循环取出节点内容

class Node{//定义一个节点类,用于保存数据和取得下一个节点
private String data;//节点中数据
private Node next;//下一个节点
public Node(String data){
this.data = data;
}
public void setNext(Node next){
this.next = next;
}
public Node getNext(){
return next;
}
public String toString(){//取出节点数据
return this.data;
} }
public class Test{
public static void main(String args[]){
//1.设置节点内容
Node root = new Node("根节点");
Node node1 = new Node("节点1");
Node node2 = new Node("节点2");
Node node3 = new Node("节点3");
//2.设置节点之间的关系
root.setNext(node1);
node1.setNext(node2);
node2.setNext(node3);
//3.取出节点内容
Node currentNode = root ; //表示当前节点
while(currentNode != null){ //当前节点不为空
System.out.println(currentNode);
currentNode = currentNode.getNext();//将当前节点设置为下一个节点
}
}
}

通过递归调用进行节点的取出

class Node{//定义一个节点类,用于保存数据和取得下一个节点
private String data;//节点中数据
private Node next;//下一个节点
public Node(String data){
this.data = data;
}
public void setNext(Node next){
this.next = next;
}
public Node getNext(){
return next;
}
public String toString(){//取出节点数据
return this.data;
} }
public class Test{
public static void main(String args[]){
//1.设置节点内容
Node root = new Node("根节点");
Node node1 = new Node("节点1");
Node node2 = new Node("节点2");
Node node3 = new Node("节点3");
//2.设置节点之间的关系
root.setNext(node1);
node1.setNext(node2);
node2.setNext(node3);
//3.取出节点内容,
print(root);
}
//定义一个递归调用类
public static void print(Node currentNode){
if(currentNode == null){
return;//结束调用
}
System.out.println(currentNode);
print(currentNode.getNext());
}
}

完善链表客户端调用,简化客户端程序代码

class Node{//定义一个节点类,用于保存数据和取得下一个节点
private String data;//节点中数据
private Node next;//下一个节点
public Node(String data){
this.data = data;
}
//=============================实现节点的添加操作==========================================
public void addNode(Node newNode){
//第一次调用addNode的当前对象 this = this.root
//第二次调用addNode的当前对象 this = this.root.next
if(this.next == null){ // 当前节点下一个节点不存在
this.next = newNode;
}else{ // 下一个节点存在
this.next.addNode(newNode);
}
}
//=============================实现节点的打印==========================================
public void printNode(){
System.out.println(this.data);//输出当前数据
if(this.next != null){
this.next.printNode();
}
}
}
class Link{
private Node root;//表示根节点
//=============================实现节点的添加操作==========================================
public void add(String data){
Node newNode = new Node(data);
if(this.root == null){//根节点不存在
this.root = newNode;
}else{//表示根节点已经存在了
this.root.addNode(newNode);
}
}
//=============================实现节点的打印==========================================
public void print(){
if(this.root != null){
this.root.printNode();
}
}
}
public class Test{
public static void main(String args[]){
Link link = new Link();
link.add("根节点");
link.add("节点1");
link.add("节点2");
link.add("节点3");
link.print();
}
}

通过内部类的方法对Node类进行封装,只可以被Link类所利用;然后实现链表的增删改查等操作;

public void add(Object obj);      数据的增加

public int size();            取得链表长度

public boolean isEmpty();       判断链表是否为空

public void contains(Object obj);    判断某一数据是否存在

public Object get(int index){}      根据索引取得数据

public void set(int index,Obect obj);  修改指定索引内容

public void remove(Object obj);;    删除指定数据

publci Object [] toArray();       将链表以对象数组的形式返回

范例:以下是相对完整的链表结构

//利用内部类对链表进行开发
class Link{
private class Node{
private String data;
private Node next;
public Node(String data){
this.data = data;
}
//==========================1.数据增加方法====================================
public void addNode(Node newNode){
if(this.next == null){ //1.this = this.root 2.this = this.root.next;...
this.next = newNode;
}else{
this.next.addNode(newNode); //递归调用
}
}
//==========================4.判断某个内容是否包含在节点之中====================================
public boolean containsNode(String data){
if(data.equals(this.data)){
return true;
}else{
if(this.next != null){
return this.next.containsNode(data);
}else{
return false;
}
}
}
//==========================5.根据索引取得数据====================================
public String getNode(int index){
if(Link.this.foot++ == index){
return this.data;
}else{
return this.next.getNode(index);
}
}
//==========================6.根据索引替换内容====================================
public void setNode(int index,String data){
if(Link.this.foot++ == index){
this.data = data;
}else{
this.next.setNode(index,data);
}
}
//==========================7.删除指定的数据====================================
public void removeNode(Node preNode,String data){//preNode表示当前节点的前一个节点
if(data.equals(this.data)){
preNode.next = this.next;//当前的节点的上一个
}else{
this.next.removeNode(this,data);
}
}
//==========================8.将链表变为数组====================================
public void toArrayNode(){
Link.this.retArray[Link.this.foot++] = this.data;
if(this.next != null){
this.next.toArrayNode();
}
}
}
//==========================上面显示的是内部类====================================
private Node root;
private int count = 0;//表示链表的长度
private int foot =0;//节点的脚标
private String[] retArray;//表示返回的数组
//==========================1.数据增加方法====================================
public void add(String data){
Node newNode = new Node(data);
if(this.root == null){ //表示根节点对象是一个空对象
this.root = newNode; //实例化根节点对象
}else{ //根节点对象已经实例化
this.root.addNode(newNode);
}
if(data != null){
this.count++;//每一次调用数据count自增一次
}
}
//==========================2.取得链表长度====================================
public int size(){
return count;
}
//==========================3.判断链表是否是空链表====================================
public boolean isEmpty(){
return this.count==0;
}
//==========================4.判断某个内容是否包含在节点之中====================================
public boolean contains(String data){
if(this.root == null||data == null){
return false;
}else{
return this.root.containsNode(data);
}
}
//==========================5.根据索引取得数据====================================
public String get(int index){
this.foot = 0;
if(this.count <= index){
return null;
}else{
return this.root.getNode(index);
}
}
//==========================6.根据索引替换内容====================================
public void set(int index,String data){
this.foot = 0;//重新设置脚标内容
if(this.count <= index){
return ;//结束方法的调用
}else{
this.root.setNode(index,data);
}
}
//==========================7.删除指定的数据====================================
public void remove(String data){
if(this.contains(data)){ //要删除的数据包含在数据里面
if(this.root.data.equals(data)){// 删除的是根节点数据
//根节点要变为原来根节点的下一个节点;
this.root = this.root.next;
}else{ //要删除的不是根节点
this.root.next.removeNode(this.root,data);
}
this.count--;
}
}
//==========================8.将链表变为数组====================================
public String [] toArray(){
if(this.root == null){
return null;
}else{
this.foot = 0;
this.retArray = new String[this.count];
this.root.toArrayNode();
return this.retArray;
}
}
}
public class Test{
public static void main(String args[]){
Link link = new Link();
System.out.println(link.isEmpty());
link.add("根节点");
link.add("节点1");
link.add("节点2");
link.add("节点3");
/*
System.out.println(link.isEmpty());
System.out.println(link.size());
System.out.println(link.contains("节点"));
System.out.println(link.get(3));
link.set(1,"修改节点内容");
System.out.println(link.get(1)); //根节点
*/
/*
System.out.println(link.get(1));
System.out.println(link.size());
link.remove("节点1");
System.out.println(link.get(1));
System.out.println(link.size());
*/
String data[] = link.toArray();
for(int x=0;x<data.length;x++){
System.out.print(data[x]+"\t");
} }
}

java中的链表编写的更多相关文章

  1. Java中的链表数据结构

    首先,我们来定义一个链表的数据结构,如下: 1 public class Link { 2 private int value; 3 private Link next; 4 public void ...

  2. java中实现链表(转)

    分析: 上述节点具备如下特征: 1. 每个节点由两部分组成(存储信息的字段,存储指向下一个节点的指针) 2. 节点之间有着严格的先后顺序. 3. 单链表节点是一种非线性的结构,在内存中不连续分配空间. ...

  3. Java中回调函数编写

    package XXX.utils; import java.io.File; import java.io.FileInputStream; import java.io.FileOutputStr ...

  4. Java中LinkedList的remove方法真的耗时O(1)吗?

    这个问题其实来源于Leetcode的一道题目,也就是上一篇日志 LRU Cache.在使用LinkedList超时后,换成ArrayList居然AC了,而问题居然是在于List.remove(Obje ...

  5. java算法01 - 链表

    1.链表 在Java中实现链表,每个节点都有一个值,然后把它链接到下一个节点.下面来看一下节点的实现 class Node<E> { private E e; private Node&l ...

  6. Java中的List集合和迭代器

    一.Java中的List集合. 终于有时间来好好整理一下Java中的集合. 首先要讲的就是List集合.Java中List集合主要将两个: 第一个是底层使用数组维护的ArrayList,第二个是底层是 ...

  7. java中如何使用列表数组

    java中如何使用列表数组 觉得有用的话,欢迎一起讨论相互学习~Follow Me 转载链接 https://blog.csdn.net/hgtjcxy/article/details/8183519 ...

  8. 面试大总结:Java搞定面试中的链表题目总结

    package LinkedListSummary; import java.util.HashMap; import java.util.Stack; /** * http://blog.csdn. ...

  9. java中的集合链表

    java中的集合类有很多种,每个都有自己的一些特点,推荐你专门在这方面研究一下,比方Vector,ArrayList,,LinkedList,Hashtable等,其中你问到的链表,是不是指Linke ...

随机推荐

  1. C++关联容器知识总结

    C++的容器类型可以分为顺序容器和关联容器两大类.顺序容器的知识可以参看我上篇的随笔<C++顺序容器知识总结>.关联容器支持通过键值来高效的查找和读取元素,这是它和顺序容器最大的区别.两种 ...

  2. Java多线程:Callable,Future,FutureTask

    一.Future Future和Callable基本是成对出现的,Callable负责产生结果,Future负责获取结果.     1.Callable接口类似于Runnable,只是Runnable ...

  3. 走进webpack(2)--第三方框架(类库)的引入及抽离

    在当代的前端开发中,很少会用原生JS来开发页面,最基本的都会使用jQuery来节省我们开发的时间和效率,而angular,vue,react的出现更是为前端开发者带来了福音.那么这篇文章就说说如何用w ...

  4. JavaEE HttpServlet 解析

    上一篇 文章中有提到,GenericServlet 是对 Servlet 的一个通用实现,并提供了一个抽象的 service() 方法.而我们的互联网是使用 Http 协议来通信的,那针对这个&quo ...

  5. 【Alpha版本】冲刺阶段 - Day3 - 逆风

    今日进展 袁逸灏:右上角两个按键的添加与实现监听(5h) 刘伟康:继续借鉴其他 alpha 冲刺博客,由于我们组的App原型可以在 alpha 阶段完成,所以不需要墨刀工具展示原型(2h) 刘先润:更 ...

  6. 201621123031 《Java程序设计》第4周学习总结

    Week04-面向对象设计与继承 1. 本周学习总结 1.1 写出你认为本周学习中比较重要的知识点关键词 关键词:继承.覆盖.多态.抽象 1.2 尝试使用思维导图将这些关键词组织起来. 1.3 可选: ...

  7. splinter web测试框架

    1.安装谷歌浏览器驱动(windows把驱动解压放在Python.exe同级目录即可) http://chromedriver.storage.googleapis.com/index.html 注意 ...

  8. django获取ip与数据重复性判定

    获取ip if request.META.has_key('HTTP_X_FORWARDED_FOR'): ip_c = request.META['HTTP_X_FORWARDED_FOR'] el ...

  9. Beta冲刺Day2

    项目进展 李明皇 今天解决的进度 优化了信息详情页的布局:日期显示,添加举报按钮等 优化了程序的数据传递逻辑 明天安排 程序运行逻辑的完善 林翔 今天解决的进度 实现微信端消息发布的插入数据库 明天安 ...

  10. v7000数据恢复_MDisk重建数据恢复方法(北亚数据恢复)

    很多工程师都有这样的疑问,MDisk重建后还能不能恢复数据呢?应该怎么做才能恢复数据呢?本文这里就以IBM V7000存储为例,详细讲解因为某个MDisk被重建导致的数据丢失的恢复方法.我们本案例中的 ...