yuqihengsheng 2012-10-26 04:05
浏览 286
已采纳

拆分字符,组成菜单 求个算法

假使有字符串 :
aa/bb/cc
aa/bb/ff
aa/bb/ee

根据字符的规律,拆分成如下形式的菜单,有没有什么解决方案捏?

aa (一级)
|- bb (二级)
|-cc 。。。。
|-ff
|-ee

考虑字符会很多,具体的结构也不固定,可能会无限N层, 递归 做 ? 存与取是个问题, 求贴码.....

  • 写回答

3条回答 默认 最新

  • fang_fumin 2012-10-26 10:31
    关注

    public class Test
    {

    public void parseString()
    {
        NodTree nodeTree = new NodTree();
        nodeTree.setNodeValue("root");
        String str = "aa/bb/cc/dd";
        String str1 = "aa/bb/cc/ee";
        String str2 = "aa/bb/cc/ff";
        String str3 = "bb/cc/ff";
    
        addNode(nodeTree,str.split("/"));
        addNode(nodeTree,str1.split("/"));
        addNode(nodeTree,str2.split("/"));
        addNode(nodeTree,str3.split("/"));
    
        print(nodeTree,0);
        System.out.println("1111111");
    
    }
    public void print(NodTree nodeTree,int w)
    {
        for(int i=0;i<w;i++)
        {
            System.out.print(" ");
        }
        System.out.println("|-"+nodeTree.nodeValue);
        for(NodTree tree:nodeTree.getNodeList())
        {
            print(tree,w+1);
        }
    }
    public void addNode(NodTree nodeTree, String[] strArr)
    {
        NodTree creatNodeTree = null;
        NodTree queryNode = null;
        NodTree parentNode = nodeTree;
        for(String str:strArr)
        {
            queryNode = parentNode.hasSubNode(str);
            if(null == queryNode)
            {
                creatNodeTree = new NodTree();
                creatNodeTree.setNodeValue(str);
                parentNode.addSunNode(creatNodeTree);
    
                parentNode =creatNodeTree;
            }
            else
            {
                parentNode = queryNode;
            }
        }
    }
    
    
    public static void main(String[] args)
    {
        Test t = new Test();
        t.parseString();
    }
    
    class NodTree 
    {
        String          nodeValue   = null;
        List<NodTree>   nodeList    = new ArrayList<Test.NodTree>();
    
    
        public String getNodeValue()
        {
            return nodeValue;
        }
    
        public void setNodeValue(String nodeValue)
        {
            this.nodeValue = nodeValue;
        }
    
        public List<NodTree> getNodeList()
        {
            return nodeList;
        }
    
        public void setNodeList(List<NodTree> nodeList)
        {
            this.nodeList = nodeList;
        }
        public void addSunNode(NodTree nodeTree)
        {
            nodeList.add(nodeTree);
        }
    
        public NodTree hasSubNode(String str)
        {
            if(null !=nodeList && !nodeList.isEmpty() )
            {
                for(NodTree nodeTree:nodeList)
                {
                    if(nodeTree.nodeValue.equals(str))
                    {
                        return nodeTree;
                    }
                }
            }
            return null;
        }
    
    
    }
    

    }

    展开全部

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)
编辑
预览

报告相同问题?

悬赏问题

  • ¥30 在CodBlock上用c++语言运行
  • ¥15 求C6748 IIC EEPROM程序固化烧写算法
  • ¥50 关于#php#的问题,请各位专家解答!
  • ¥15 python 3.8.0版本,安装官方库ibm_db遇到问题,提示找不到ibm_db模块。如何解决?
  • ¥15 TMUXHS4412如何防止静电,
  • ¥30 Metashape软件中如何将建模后的图像中的植被与庄稼点云删除
  • ¥20 机械振动学课后习题求解答
  • ¥15 IEC61850 客户端和服务端的通讯机制
  • ¥15 MAX98357a(关键词-播放音频)
  • ¥15 Linux误删文件,请求帮助
手机看
程序员都在用的中文IT技术交流社区

程序员都在用的中文IT技术交流社区

专业的中文 IT 技术社区,与千万技术人共成长

专业的中文 IT 技术社区,与千万技术人共成长

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

客服 返回
顶部