递归常见java面试题–第四部分:迭代和递归-java开发java经验技巧

递归迭代  时间:2021-04-10  阅读:()

常见Java面试题-第四部分迭代和递归-Java开发Java经验技巧

常见Java面试题-第四部分迭代

(iteration)和递归(recursion)

本文  ImportNcw-郑雯未经许可禁止

ImportNew注本文是ImportNew编译整理的Java而试题系列文章之一。你可以从这里查看全部的Java面试系列。

Q.请写一段代码来计算给定文木内字符“A”的个数。分别用迭代和递归两种方式。

A.假设给定文本为” AAA rating" 。迭代方式就很直观,如下:publ ic class Iterat ion {publ ic int countA(String input ) {if ( input二二nul1 | | input , length( )二二0) { rcturn 0;

}int count二0;for ( int i二0; i < input , length( ) ; i++) { if ( in put . substrin g( i , i + 1 ) ・ cquei lsC'A” ) ) { count++;

}

}return count ;

}publ ic static void main(String[ ] args) {

System, out . print ln(new Iteration( ) .countA( 〃AAA rating〃 ) ) // Ans . 3

}

}

接下來递归方式的代码如2publ ic class RecursiveCal l {publ ic int countA(String input )

// exi t condi tion - recursive cal ls must have an exi t condi tion if

( input二二nul l | | input , length( ) == 0) {

return 0;

} int count = 0;

//check first character of the inputif ( input . substring(0, 1) . equal s ){ count二1 ;

//recursive cal l to evaluate rest of the input

//( i . e. 2nd character onwards) return count + countA( input .substring( l ) ) ;

}publ ic static void main(String[ ] args) {

System, out . printin (new RecursiveCal l ( ) . countA( 〃AAArat ing〃 ) )  // Ans . 3

递归比较难以理解我们用下面的图來进行说明。

Q.理解递归需要了解哪些概念?

A.可重入方法(re-entrant method)是可以安全进入的方法即使同一个方法正在被执行深入到同一个线程的调用栈里面也不会影响此次执行的安全性。一个非可重入方法则不是可以安全进入的。例如加入写文件或者向文件屮写入日志的方法不是可重入方法时有可能会毁坏那个文件。

如果一个方法调用了其自身的话我们称之为递归调用。假定栈空间足够的话尽管递归调用比较难以调试在Ja腹语言中实现递归调用也是完全可行的。递归方

法是众多算法小替代循环的一个不错选择。所有的递归方法都是可重入的但是不是所有可重入的方法都是递归的。

栈遵守LIFO (Last In First Out)规则因此递归调用方法能够记住“调用者” 并口知道此轮执行结束之返冋至当初的被调用位置。递归利用系统栈来存储方法调用的返回地址。 Java是一种基于栈设计的编程语言。

顺着这个思路还有那些问题町以用來面试

Q・什么情况下应该采用递归

A.上而的例子屮其实不必采用递归循环的方式可以达到目的但是在某些情况下采用递归方式则代码会更加简短易读。递归方法在循环树结构以及避免丑陋的嵌套循环的情况下是非常好用的。

Q・什么是尾递归为什么需要尾递归上面的代码用尾递归方式如何重写

A.常规递归方法(亦称头递归)在上而演示了这种方式会增加调用栈的大小。每次递归其入口需要被记录在栈屮。方法返回之前需要给coun t A(input, subs tring(l)的结果加一个coun t 。假定count大于1 ,那么返冋结果就是coun t + coun tA(input, subs tring(l)),当然事先要算岀来countA( input , substring( l ) )才行。同时,这也意味着直到coun tA(input, subs tring(1)计算出来才能得到最终的结果。因此最后需要做的事其实是加法运算而非递归本身。

尾递归的好处是什么

在尾递归屮最后要做的是递归加法运算在之前就已经完成了。一轮递归调用完毕后就没有其他事情了(除了加法运算) 因此调用时生成的信息也就没什么用了。这些无用信息可以丢弃然后用一组新的参数来调用一次递归方法来产生一个新的结果。这也就是说栈调用减少带来了内存消耗减少并冃程序的性能更好。尾递归重写的代码如下publ\ c class Tai 1RecursiveCal1 {publ ic int countA(String input ) {

// exi t condi tion - recursive cal ls must have an exi t condi t ionif ( input二二nul l | | input . 1 ength( ) == 0) {return 0;

}return countA( input , 0) ;

}publ ic int countA(String input , int count ) {if ( input , length( )二二0) {return count ;

}

// check first character of the inputif ( input . substring(0, 1) . equal s ){count = count + 1 ;

}

// recursive cal l is the last cal l as the count is cumulative returncountA( input . subst ring( l ) , count ) ;

}publ ic static void main(String[ ] args) {

System, out . printin(new Tai lRecursiveCal l ( ) . countA( 〃AAA rating〃 ) ) ;扩展阅读

• 常见Java面试题-第一部分:非可变性(Immutab ility)和对象引MJ(Obj ect reference)

• 常见Java面试题-第二部分 equal s与二二

• 常见Java面试题-第三部分重载(overlo ading)与覆盖(overriding)

英文原文 Java Success ,编译 ImportNew?-?郑雯

译文链接 . importnew. 2329.

【如需请在正文屮标注并保留原文链接、译文链接和译者等信息谢谢合作 】关于 郑雯

2009年北航计算机学院毕业加入IBMCDL至今。从事过web产品测试及开发工作。口前兴趣主要在游泳和自助穷游上。

查看郑雯的更多文章>>

CloudCone:洛杉矶MC机房KVM月付1.99美元起,支持支付宝/PayPal

CloudCone是一家成立于2017年的国外VPS主机商,提供独立服务器租用和VPS主机,其中VPS基于KVM架构,多个不同系列,譬如常规VPS、大硬盘VPS等等,数据中心在洛杉矶MC机房。商家2021年Flash Sale活动继续,最低每月1.99美元,支持7天退款到账户,支持使用PayPal或者支付宝付款,先充值后下单的方式。下面列出几款VPS主机配置信息。CPU:1core内存:768MB...

妮妮云(119元/季)日本CN2 2核2G 30M 119元/季

妮妮云的知名度应该也不用多介绍了,妮妮云旗下的云产品提供商,相比起他家其他的产品,云产品还是非常良心的,经常出了一些优惠活动,前段时间的八折活动推出了很多优质产品,近期商家秒杀活动又上线了,秒杀产品比较全面,除了ECS和轻量云,还有一些免费空间、增值代购、云数据库等,如果你是刚入行安稳做站的朋友,可以先入手一个119/元季付的ECS来起步,非常稳定。官网地址:www.niniyun.com活动专区...

香港 E5-2650 16G 10M 900元首月 美国 E5-2660 V2 16G 100M 688元/月 华纳云

华纳云双11钜惠出海:CN2海外物理服务器终身价688元/月,香港/美国机房,免费送20G DDos防御,50M CN2或100M国际带宽可选,(文内附带测评)华纳云作为一家专业的全球数据中心基础服务提供商,总部在香港,拥有香港政府颁发的商业登记证明,APNIC 和 ARIN 会员单位。主营香港服务器、美国服务器、香港/美国OpenStack云服务器、香港高防物理服务器、美国高防服务器、香港高防I...

递归迭代为你推荐
音视频iphonelinux防火墙设置如何使用iptables命令为Linux系统配置防火墙360免费建站怎样给360免费自助建站制作的企业网站做一级域名解析绑定?开心001开心001与开心网怎么不一样,哪个是真的?免费代理加盟免费加盟代销怎么回事,能具体介绍下么qq挂件有没有免费的QQ挂件啊?长沙电话号码升位长沙的座机什么时候变成8位的,急!在线等答案,那如果之前的7位数是不是都会变啊?变成什么样了呢?论坛勋章论坛勋章设置安与骑士关于安与骑兵的三年三天,想知道所唱的故事有没有出处,或者是曲子的。显示ip手机上网为什么显示IP是外地的?
淘宝抢红包攻略 namecheap rak机房 12306抢票攻略 网通服务器ip php免费空间 京东商城0元抢购 域名评估 免费防火墙 php空间购买 paypal注册教程 网页加速 宿迁服务器 云销售系统 服务器托管价格 美国主机 windowsserverr2 发证机构 godaddy域名 美国达拉斯 更多