java 中递归的运用_java中的递归思想及应用

递归就是自己调自己,最需要注意的就是结束条件,否则可能就是死循环,导致内存溢出

public T a(Object x,Object y)

{

if(条件true)

{

a(x1,y1);

}

else

{

return f(x,y);

}

}

例如:

1.求阶乘

5!=5x4x3x2x1

分析:递归是一层一层推进,第一层是 5*4,第二层4*3,第三层,3*2,递归入参分别是5,4,3,2,1,当为1时返回1,递归终止

public int f(n)

{

if(n=1)

{

return 1;

}

else

{

return n*f(n-1);

}

}

2.获取某一父节点下的所有子节点,多层级

分析:第一层入参是父节点本身,第二层入参是父节点下的第一层子节点,第三层是第一层所有节点下的子节点,当节点是叶子节点(没有节点的父节点是它)时,不用继续向下。

只要不是叶子节点,父节点找到的节点都是其子集setchild();

child

{

menuA

child

{

menuA1

child{}

}

menuB

child{}

.....

}

//菜单类

public class Menu

{

private int pid;

private int menuId;

private int menuName;

List

.....

}

//获取所有菜单对象

List

//查询菜单树方法

public  List

{

List

for(Menu menu: menus)

{

if(menu.getPid== pid ) // 入口,说明当前pid下存在子节点

{

menu.setChild(getMenuTreeByPid(menus,menu.getMenuId));

child.add(menu);

}

}

return child;

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值