求java递归算法,帮我把模块表里面的数据遍历,然后转成json形式传到前台,形成树形事后加分+,非常感谢

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了求java递归算法,帮我把模块表里面的数据遍历,然后转成json形式传到前台,形成树形事后加分+,非常感谢相关的知识,希望对你有一定的参考价值。

参考技术A private void putModule(Module module, List<Module> list)

Integer moduleId = module.getModuleId();
for (Module m : list)

if (m.getModuleParentId().equals(moduleId))
if (module.getmodules() == null )
List<Module> modules = new ArrayList<Module>():
module.setModules(modules);



module.getModules().add(m);




private void parseModule(List<Module> modules, List<Module> sources)

for (Module m : modules)

putModule(m, sources);

if (m.getModules().size() > 0)

parseModule(m.getModules(), sources);





// 调用这个方法即可,插入查询回来的列表
public Module dealTopLevel(List<Module> modules)
Module module = null;
for (Module m : modules)

if (m.getModuleLevel() == 0)
module = m;
break;



putModule(module, modules);

if (module.getModules().size() > 0)

parseModule(module.getModules(), modules);

return module;


注意在实体类中加入 List<Module> modules;的属性
Spring直接返回这个Module即可得到结构

辛苦写的,请采纳

递归算法及递归算法求二叉树的高度(二叉链表存储)

题目描述

 假设二叉树采用二叉链表存储结构,设计一个非递归算法求二叉树的高度。

算法思想

 采用层次遍历的算法,设置变量level来记录当前结点所在的层数,设置变量last指向当前层的最右边的结点,每次层级遍历出队时与last指针比较,如果相等,则层数加1,并让last指向下一层的最右边的结点,直到遍历完成。那么最后的level的值即为二叉树的高度。


实现代码

实现代码:

 非递归算法:

int Depth(BNode *root){
    int level = 0; //level为层数
    BNode *last = root;//last为下一层的最右结点
    if(root == NULL){ //树空,则高度为0
        return 0;
    }
    queue<BNode *> treenode; //申请一个队列
    treenode.push(root); //根结点入队
    while(!treenode.empty()){ //队不空时循环
        BNode *p = treenode.front(); //队首
        treenode.pop(); //根结点出队
        if(p->lchild != NULL){ //如果存在左子树,则左子树根结点入队
            treenode.push(p->lchild);
        }
        if(p->rchild != NULL){ //如果存在右子树,则右子树根结点入队
            treenode.push(p->rchild);
        }
        if(p == last){ //如果刚才出队的是该层最右结点
            level++; //层数加1
            last = treenode.back(); //last指向下层
        }
    }
    return level;
}

 递归算法:

int Depth2(BNode *root){
    if(root == NULL){ //空树,高度为0
        return 0;
    }
    int left = Depth2(root->lchild); //左子树高度
    int right = Depth2(root->rchild); //右子树高度
    return (left>right? left+1 : right+1); //树的高度为最大子树的高度加上根结点
}

完整代码及实例

完整代码:

#include<bits/stdc++.h>
using namespace std;

typedef struct BNode{
    char data;
    struct BNode *lchild;
    struct BNode *rchild;
}BNode;

const int N = 100;
char str[N]; //存储先序遍历序列
int i; //标记处理到哪一个字符了
BNode *BulidTree(){
    if(str[i] == '#'){
        i++; //处理下一个字符
        return NULL;
    }else{
        //新建一个结点
        BNode *p = (BNode *)malloc(sizeof(BNode));
        p->data = str[i];
        p->lchild = NULL;
        p->rchild = NULL;
        i++;
        p->lchild = BulidTree();
        p->rchild = BulidTree();
        return p;
    }
}

//非递归算法
int Depth(BNode *root){
    int level = 0; //level为层数
    BNode *last = root;//last为下一层的最右结点
    if(root == NULL){ //树空,则高度为0
        return 0;
    }
    queue<BNode *> treenode; //申请一个队列
    treenode.push(root); //根结点入队
    while(!treenode.empty()){ //队不空时循环
        BNode *p = treenode.front(); //队首
        treenode.pop(); //根结点出队
        if(p->lchild != NULL){ //如果存在左子树,则左子树根结点入队
            treenode.push(p->lchild);
        }
        if(p->rchild != NULL){ //如果存在右子树,则右子树根结点入队
            treenode.push(p->rchild);
        }
        if(p == last){ //如果刚才出队的是该层最右结点
            level++; //层数加1
            last = treenode.back(); //last指向下层
        }
    }
    return level;
}

//递归算法
// int Depth2(BNode *root){
//     if(root == NULL){ //空树,高度为0
//         return 0;
//     }
//     int left = Depth2(root->lchild); //左子树高度
//     int right = Depth2(root->rchild); //右子树高度
//     return (left>right? left+1 : right+1); //树的高度为最大子树的高度加上根结点
// }

int main(){
    scanf("%s",str);
    i = 0;
    BNode *root = BulidTree();
    int level = Depth(root);
    printf("%d\\n",level);
    return 0;
}

运行结果:
在这里插入图片描述

实例中的二叉树为:
在这里插入图片描述

以上是关于求java递归算法,帮我把模块表里面的数据遍历,然后转成json形式传到前台,形成树形事后加分+,非常感谢的主要内容,如果未能解决你的问题,请参考以下文章

求翻译!!!!急求!谁能帮我把下面的东西翻译成英文啊!!!!  翻译的好的加送50财富值!

求高手给个遍历算法

求SQL多表查询公式。从A表查询结果去关联B表里面的字段

java数据结构之二叉树遍历的非递归实现

Java递归遍历集合

DS二叉树--后序遍历非递归算法