最近由于课程变化,学习计划也跟着改动,留给我写博客的时间也越来越少。今天晚上没有课,抽空过来图书馆写一写,许久不写感觉都有点陌生了!
今天要和大季家分享的衔接了上一篇博客,是关于方法的嵌套调用与递归调用,是学习方法过程中不可避免的两个版块,大家一起来看一看!
关于嵌套调用:
在Java语言中,各个方法之间是平行的,不存在上一级方法和下一级方法的问题,并且在Java语言中允许在一个方法的定义中出现对另一个方法的调用,于是便有了方法的嵌套调用,即在被调用的方法中又电泳其他方法。例如:执行main方法中调用a方法的语句时,即转去执行a方法,在a方法中调用b方法时,又转去执行b方法,b方法执行完毕返回a方法的断点继续执行,a方法执行完毕返回main方法的断点继续执行。
计算 s=(2*2)!+(3*3)!
public class demo{ public static void main(String[] args){// int i;long s=0; for(i=2;i<=3;i++) s=s+fun1(i); System.out.println(s); } static long fun1(int p) {//定义fun1方法用来计算平方值并调用fun2方法 int k;long r; k=p*p; r=fun2(k); return r; } static long fun2(int q) {//计算阶乘值的方法fun2 int i;long c=1; for(i=1;i<=q;i++) c=c*i; return c; } }
解析:在主程序中,执行循环程序依次把i值作为实参调用方法fun1求i的平方的值。在fun1中又发生了对方法fun2的调用,这时是把i的平方的值作为实参去调用fun2,在fun2中完成(i*i)!的计算。fun2执行完毕之后把C值(即i*i!)返回给fun1,再由fun1返回主方法实现叠加。
关于递归调用:
其实递归方法就是直接或者间接调用自身的方法。许多数学函数都是使用递归来定义的,这样的 函数在Java中也能来定义与调用。设计算n!的方法为fun1,根据n阶乘的递归定义方式,计算fun1的递归算法可以简单地描述如下:
if(n==0) return 1; else return n*fun1(n-1);
例:输入一个非负整数,显示该数的阶乘值。
import java.util.Scanner; public class demo{ public static void main(String[] args){ Scanner input = new Scanner(System.in); System.out.println("请输入一个非负整数:"); int n = input.nextInt(); System.out.println(n+"的阶乘值是:"+fun1(n)); } public static long fun1(int n) { if (n==0) return 1; else return n*fun1(n-1); } }
其实嵌套调用与递归调用都只是方法的拓展,只是前者是调用另一个方法,而后者是调用自身的方法。
时间: 2024-10-20 01:32:32