(11.06)Java小知识

Posted 不只学Java

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了(11.06)Java小知识相关的知识,希望对你有一定的参考价值。

  最近由于课程变化,学习计划也跟着改动,留给我写博客的时间也越来越少。今天晚上没有课,抽空过来图书馆写一写,许久不写感觉都有点陌生了!

  今天要和大季家分享的衔接了上一篇博客,是关于方法的嵌套调用与递归调用,是学习方法过程中不可避免的两个版块,大家一起来看一看!

  关于嵌套调用

  在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);
    }
}

  其实嵌套调用与递归调用都只是方法的拓展,只是前者是调用另一个方法,而后者是调用自身的方法。

 


以上是关于(11.06)Java小知识的主要内容,如果未能解决你的问题,请参考以下文章

android小知识点代码片段

python小知识片段

python小知识片段

11.06

11.06

11.06第九次