java - 如何在Jsp中循环自引用类?

标签 java jsp data-structures html-lists self-reference

我编写了一个 Node 类,用于将 tree 数据结构存储为,

该节点看起来像,enter image description here

我想开发的树,enter image description here

public class Node1
{
  public String data;
  public Node1 left;
  public Node1 right;   
  public static int level=0;
  public Node1(String data)
  {
     this.data=data;
     this.left=null;
     this.right=null;
  }
}

我将节点存储为,

 public void add(Node1 ht,Node1 tm,String Data)
  {
    String LNsearchData=Data.substring(0,Data.indexOf("#"));
    Data=Data.substring(Data.indexOf("#")+1);
    //System.out.println("righ"+LNsearchData);
    boolean rights=false,lefts=false;
      while(true)
      {
          if(ht.data.startsWith(LNsearchData))
          {
              System.out.println("righ"+tm.data);
              if(ht.right==null)
              {   rights=true;
                  break;
              }
               ht=ht.right;
               if(Data.length()==0)
                   break;
               LNsearchData=Data.substring(0,Data.indexOf("#"));
               Data=Data.substring(Data.indexOf("#")+1);
           }
          else
          {
              if(ht.left==null)
              {

                  break;
              }
               ht=ht.left;

               if(Data.length()==0)
                   break;
               LNsearchData=Data.substring(0,Data.indexOf("#"));
               Data=Data.substring(Data.indexOf("#")+1);
          }
      }
      if(rights==false)
      {
          System.out.println("righ"+tm.data);
          while(ht.left!=null)
          {
              ht=ht.left;
          }
          ht.left=tm;
      }
      else
      {
          while(ht.right!=null)
          {
              ht=ht.right;
          }
          ht.right=tm;
      }


}

现在我想在jsp中将这个节点对象显示为树结构,所以在jsp中我这样做了,

   <%
    Node1 n1=new Node1("A");
    n1.add(n1, new Node1("B"),"A#");
    n1.add(n1, new Node1("C"),"A#B#");
    n1.add(n1, new Node1("K"),"A#B#C#");
    n1.add(n1, new Node1("E"),"A#");
    n1.add(n1, new Node1("F"),"A#");
    n1.add(n1, new Node1("X"),"X#");

    n1.level=1;
    n1.traverse(n1);

%>

在jsp中构建树结构,

<%!
public void traverse(Node1 di,JspWriter out)throws IOException
{
   //System.out.println("Par"+di.data+"level"+level);
   out.println("<li class='folder'>"+di.data);
   out.println("  <ul>");
    if(di.right!=null)
    {
      //level++;


      traverse(di.right,out);
      //level--;
    }
    if(di.left!=null)
    {
        out.print("<ul>");
        //out.print("left: "+di.data+"\n");
        traverse(di.left,out);
    }
    if(di.left==null&&di.right==null)
    {
        out.println("</ul>");
    }
   //System.out.println("returnd "+level);

}
%>
<div id="tree">
<%traverse(n1,out); %>
 </div>

我面临的问题是我只能遍历节点的右侧,但我必须遍历节点的两侧。任何人都可以帮我解决这个问题吗?

最佳答案

我猜 ul 标签没有明确定义。 试试这个:

<%!
public void traverse(Node1 di,JspWriter out)throws IOException
{

    //System.out.println("Par"+di.data+"level"+level);
    out.println("<li class='folder'>"+di.data);
    if(di.right!=null)
    {
      out.print("<ul>");
      traverse(di.right,out);
      out.println("  </ul>");
    }
    if(di.left!=null)
    {
        traverse(di.left,out);
    }

}
%>
<div id="tree">
  <ul>
    <%traverse(n1,out); %>
  </ul>
 </div>

关于java - 如何在Jsp中循环自引用类?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28764642/

相关文章:

java - Junit5 TemporaryFolderExtension 依赖项

java - 移动端代码编程

java - 将 post 数据从 JSP 发送到 Java Servlet

jsp - 在 JSP 页面中动态导入文件

java - 在单个二维数组中存储多种数据类型

java - 在java中将设置存储在对象数据类型的散列图中的替代方案?

java - 如何使用Servlet和Ajax?

c# - 在 32 位和 64 位运行时编码(marshal)结构时的不同行为

java - 线性数据结构的对称性和不对称性

java - 是否可以用堆实现最小优先级队列,或者是否需要二叉堆?