- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
java代码实现递归
thinkinjava书中使⽤递归分析
代码如下:
publicclassSnakeimplementsCloneable{
privateSnakenext;
privatecharc;
//Valueofi==numberofsegments
Snake(inti,charx){
c=x;
if(--i0)
next=newSnake(i,(char)(x+1));
}
voidincrement(){
c++;
if(next!=null)
next.increment();
}
publicStringtoString(){
Strings=:+c;
if(next!=null)
s+=next.toString();
returns;
}
publicObjectclone(){
Objecto=null;
try{
o=super.clone();
}catch(CloneNotSupportedExceptione){}
returno;
}
publicstaticvoidmain(String[]args){
Snakes=newSnake(5,a);
System.out.println(s=+s);
Snakes2=(Snake)s.clone();
System.out.println(s2=+s2);
s.increment();
System.out.println(
afters.increment,s2=+s2);
}
}
⽰意图如下:
输出如下:
s=:a:b:c:d:e
s2=:a:b:c:d:e
afters.increment,s2=:a:c:d:e:f
分析:
在讲clone()的时候,为说明浅复制,举例此类;
⼀条Snake(蛇)由数段构成,每⼀段的类型都是Snake。所以,这是⼀个⼀段段链接起来的列表。
所有段都是以循环⽅式创建的,每做好⼀段,都会使第⼀个构建器参数的值递减,直⾄最终为零。
⽽为给每段赋予⼀个独⼀⽆⼆的标记,第⼆个参数(⼀个Char)的值在每次循环构建器调⽤时都会递增。
increment()⽅法的作⽤是循环递增每个标记,使我们能看到发⽣的变化;
⽽toString则循环打印出每个标记。
使⽤递归打印阶乘
@Test
publicvoidtest(){
//10!=10*9*8*。。。。1;
System.out.println(get(36));
}
publicstaticlongget(intn){
longresult=1;
if(n==1){
result*=1;
}
else{
result=n*get(n-1);
}
returnresult;
}
使⽤递归打印斐波那契数列
//第⼀和第⼆项是1,后⾯每⼀项是前⼆项之和,即1,1,2,3,5,8,13,...。
//递归实现:
publicstaticintfun02(intn){//n是第n个数,从0开始
if(n1){
return(fun02(n-1)+fun02(n-2));
}else{
文档评论(0)