java表述环形链表_JAVA环形链表解决约瑟夫环问题

大神求教···classChild{intnum;ChildnextChild=null;publicChild(intnum){this.num=num;}}classPlay{ChildfirstChild=null;Childtemp=null;//初始化环形链表publicvoidcreatLink()...

大神求教···

class Child

{

int num;Child nextChild=null;

public Child(int num)

{this.num=num;}

}

class Play

{

Child firstChild=null;Child temp=null;

//初始化环形链表

public void creatLink()

{

for(int i=1;i<10;i++)

{

if(i==1)

{ Child a=new Child(i);

this.firstChild=a;

this.temp=a; }

else if 省略i=10尾接头temp.nextChild=this.firstChild;

else{Child a=new Child(i);

temp.nextChild=a;

temp=a;}

}

}

}

简化了下代码,环形链表这我没理解,for里面循环只是temp、temp.nextChild不断跳动被重新赋值,变没有生成完整的Child(1) Child(2)Child(3) 那链表在哪呢?

public void show() {

Child temChild = this.firstChild;

do {

System.out.println(temChild.no + "###");

temChild = temChild.nextChileChild;

} while (temChild != this.firstChild);

接这个能打出指针跳动,链表没懂这个我只能理解成下面这样···

temChild = this.firstChild.nextChileChild

temChild = this.firstChild.nextChileChildnextChileChild

展开

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值