Loading [MathJax]/jax/output/CommonHTML/config.js
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >【Java】——深入探索Java方法递归与输入输出

【Java】——深入探索Java方法递归与输入输出

作者头像
User_芊芊君子
发布于 2025-04-08 12:46:20
发布于 2025-04-08 12:46:20
21300
代码可运行
举报
运行总次数:0
代码可运行
【前言】

Java编程的广阔领域中,方法递归输入输出(I/O)是两个极为重要的概念。方法递归为解决特定类型的问题提供了一种优雅且高效的思路;而输入输出则是Java程序与外部世界交互的桥梁,无论是读取文件数据,还是向控制台输出信息,都离不开I/O操作。深入理解并熟练运用这两者,对于提升Java编程能力至关重要。

一、方法递归

1.什么是递归

我们小时候应该都听过这样一个故事,“从前有座山,山上有座庙,庙里有个老和尚讲故事,讲的是:“从前有座山,山上有座庙,庙里有个老和尚讲故事,讲的是:“从前有座山,山上有座庙,庙里有个老和尚讲故事… 这个故事就很好的体现出了递归,它有一个特征:自身中又包含了自己这种思想在编程和数学中非常有用 so:

递归是指在一个方法内部调用自身的过程。它基于一个简单而强大的概念:将一个复杂的问题分解为一个或多个与原问题相似但规模更小的子问题,当子问题小到可以直接解决时,递归就会停止。

递归的必要条件:

  • 将原问题分解成其子问题(子问题必须与原问题解法相同)
  • 递归出口(结束条件,也就是其实条件)

2. 代码示例

递归求N的阶乘

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
public class Test {

    public static int fac(int N){
        if(N == 1){
            return 1;
        }
        int ret = N * fac(N-1);//调用自身
        return ret;
}

    public static void main(String[] args) {
      int ret = fac(5);
        System.out.println(ret);
    }
}

执行结果:

3.递归的执行过程

递归的程序执行过程还是比较复杂的,我们要先理解方法的执行过程,尤其是方法执行结束后,回到调用位置继续执行

计算5的阶乘,fac(5) 会调用发出fac(4) , fac(4) 又会调用fac(3) ,以此类推…直到fac(1)。然后从fac(1) 开始返回结果,逐步计算出fac(5)的值,这个过程在Java虚拟机调用栈(方法调用时,会有一个“栈”这样的内存空间描述当前的调用关系,称为调用栈)中进行,每一次递归调用都会在调用栈中压入一个新的栈帧,包含这次调用的参数和局部变量等,当递归返回时,相应的栈帧从调用栈中弹出。

这个图片可以帮助我们更好的理解

4.递归的优缺点

  • 优点在于代码简洁、优雅,符合人类对问题的分解思考方式,对于某些问题如树形结构遍历,递归实现非常直观。
  • 由于递归调用会消耗栈空间,对于规模较大的问题,可能导致栈溢出错误。此外,递归方法的执行效率相对较低,因为每次调用都伴随着方法调用开销和栈操作。

5.递归使用实例

  1. 按顺序打印⼀个数字的每⼀位
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
public class Test {
    public static void main(String[] args) {
        print(2025);
    }

    public static void print(int n) {
        if (n <= 9) {
            System.out.println(n);
        } else {
            print(n / 10);
            System.out.println(n % 10);
        }
    }
}

执行结果:

2.递归求 1 + 2 + 3 + … + 10

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
public class Test {
    public static void main(String[] args) {
        int ret = sum(10);
        System.out.println(ret);
    }
    public static int sum(int n){
        if(n == 1){
            return 1;
        }
        int ret = n+sum(n-1);
        return ret;
    }
}

执行结果:

3.求斐波那契数列的第 N 项

斐波那契数列的定义是:从第三项开始,每一项都等于前两项之和。该数列的前两项通常定义为0和1,即F(0)=0,F(1)=1,那么后续的项依次为:F(n)=F(n- 1)+F(n - 2)(n\geq2,n为整数)。所以这个数列的前几项就是0,1,1,2,3,5,8,13,21,34…

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
public class Test {
    public static void main(String[] args) {
       int tmp = fib(6);//第6项
        System.out.println(tmp);
    }
    public static int fib(int n){
        if(n == 1 || n == 2){
            return 1;
        }
        int ret = fib(n-1)+fib(n-2);
        return ret;
    }
}

执行结果:

二、Java中的输入输出

1.输出

1.1 基本语法
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
System.out.println(msg);//输出字符串,换行
System.out.print(msg);//不换行
System.out.printf(format, msg);//格式化输出

  • print 后面带\n 就换行
  • 与C语言基本一致
  • 快捷键:输入sout 回车
1.2 格式化字符串

2.输入

2.1 键盘输入的四个步骤:

  • 导包import java.util.Scanner;
  • 创建Scanner 类型对象: Scanner scan = new Scanner(System.in);
  • 调用Scanner类的相关方法:(nextInt)/(nextFloat)…
  • 调用关闭方法:scan.close()
2.2 怎么导包

输入要使用Scanner读取字符串,整型,浮点数,(Scanner就是一个工具)但使用Scanner需要导入java.util.Scanner

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
import java.util.Scanner;

页面顶部就会出现这一句,这样就完成导包了

2.3 示例

1.输入一个数,并打印

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
public class Test {
    public static void main(String[] args) {
        //           =  对象——>System.in 标准输入
        Scanner scan = new Scanner(System.in);
        int a = scan.nextInt();//输入
        System.out.println(a);
    }
}

执行结果:

2.打印姓名/年龄/身高/体重

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
public class Test {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        System.out.println("请输入你的姓名:");
        String name = sc.nextLine();
        System.out.println(name);
        System.out.println("请输入你的年龄:");
        int age = sc.nextInt();
        System.out.println(age);
        System.out.println("请输入你的身高:");
        float h = sc.nextFloat();
        System.out.println(h);
        System.out.println("请输入你的体重:");
        float w = sc.nextFloat();
        System.out.println(w);
        sc.close();
    }
}

执行结果:

2.4 多组输入

循环读取

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
public class Test {
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        while (scanner.hasNextInt()){
            int n = scanner.nextInt();
            System.out.println(n);
        }
    }
}

执行结果:

注意:

【总结】 Java方法递归提供了一种独特的问题解决思路,适用于具有递归结构的问题,但使用时需注意栈溢出和性能问题。Java输入输出流体系为程序与外部世界交互提供了强大而灵活的工具,熟练掌握这两个重要的Java特性,将使开发者在处理各种编程任务时更加得心应手。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2025-04-08,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
《JavaSE-习题篇二》之七个题目,十六张图,让你不惧递归。
学习方法后,我们来学习一种特殊调用方法的方式,即递归。本篇文章将介绍什么是递归,以及递归的使用规则和注意事项,最后通过几道经典的题目来加深对递归的理解。
用户10517932
2023/10/07
3290
《JavaSE-习题篇二》之七个题目,十六张图,让你不惧递归。
知识改变命运 第六集:递归
从前有坐山,山上有座庙,庙里有个老和尚给小和尚将故事,讲的就是: "从前有座山,山上有座庙,庙里有个老和尚给小和尚讲故事,讲的就是: “从前有座山,山上有座庙…” “从前有座山……” "
用户11319080
2024/10/17
1500
知识改变命运 第六集:递归
【Java探索之旅】方法重载 递归
假设现在我们需要求两个数的和,要求根据数据的类型返回相应的返回值。那么就需要写一个整数和的方法、一个浮点数和的方法。如果类似的要求很多,你取名字都是一件极其麻烦的事情,这里就需要用到方法的重载了。
屿小夏
2024/04/18
1370
【Java探索之旅】方法重载 递归
万字详解递归与递推
递归指由一种(或多种)简单的基本情况定义的一类对象或方法,并规定其他所有情况都能被还原为其基本情况。上面的故事就是一个简单的递归,当然还有斐波那契数列等等,一系列我们熟知的。
秋名山码神
2023/02/10
6150
万字详解递归与递推
【Java篇】一法不变,万象归一:方法封装与递归的思想之道
方法是组织代码的一种形式,它允许将重复性代码封装在一个单独的块中,从而实现模块化。Java 方法类似于 C 语言中的“函数”。它是解决多次使用相同代码的理想方式。通过方法,我们不仅可以提高代码的可重用性,还能提高代码的可维护性和可读性。
半截诗
2025/03/15
2330
【Java篇】一法不变,万象归一:方法封装与递归的思想之道
Java——方法 递归使用及练习
起始条件: N = 1 的时候, N! 为 1. 这个起始条件相当于递归的结束条件.
RAIN7
2021/08/11
8270
Java从入门到“放弃”(精通)之旅——方法的使用⑤
在编程领域,代码如同精密的齿轮相互咬合驱动程序运转。随着项目规模渐长,重复的代码片段如同冗余的齿轮,不仅增加负重,还易导致故障。
想不明白的过度思考者
2025/10/29
620
Java从入门到“放弃”(精通)之旅——方法的使用⑤
【Java SE语法篇】5.方法
在编程的过程中,经常会出现一部分代码多次使用的情况,比如计算多边形面积,输出固定格式的文字等。
爱敲代码的小杨.
2024/05/07
1640
【Java SE语法篇】5.方法
Java输入输出
引言:在平时java开发中,被输入输出搞得头疼。特此写下这篇博客,一是为了总结输入输出,二是为了和大家分享。如果大家觉得写得好,就请高抬贵手点个赞呗!!!
全栈程序员站长
2022/07/21
1.9K0
Java输入输出
Java基础-20(01)总结,递归,IO流
1:递归(理解) (1)方法定义中调用方法本身的现象 举例:老和尚给小和尚讲故事,我们学编程 (2)递归的注意事项; A:要有出口,否则就是死递归 B:次数不能过多,否则内存溢出 C:构造方法不能递归使用 package cn.itcast_01; /* * 递归:方法定义中调用方法本身的现象 * * 方法的嵌套调用,这不是递归。 * Math.max(Math.max(a,b),c); * * public void show(int n) { * if(n <= 0) {
Java帮帮
2018/03/16
8360
Java方法的递归
推荐一个网站给想要了解或者学习人工智能知识的读者,这个网站里内容讲解通俗易懂且风趣幽默,对我帮助很大。我想与大家分享这个宝藏网站,请点击下方链接查看。 https://www.captainbed.cn/f1
鲜于言悠
2024/05/26
2490
Java方法的递归
【Java探索之旅】从输入输出到猜数字游戏
看到这里,你学已经会了如何在Java中进行简单的输入输出操作,包括输出到控制台和从键盘输入。同时,通过一个有趣的猜数字游戏示例,你也了解了如何运用分支语句和循环语句来实现一个小游戏。希望这些基础知识能够帮助你更好地理解Java编程,并为你未来的学习之路打下坚实的基础。继续努力,编程之路将会越发精彩!
屿小夏
2024/04/18
3100
【Java探索之旅】从输入输出到猜数字游戏
Java输入与输出详解
推荐一个网站给想要了解或者学习人工智能知识的读者,这个网站里内容讲解通俗易懂且风趣幽默,对我帮助很大。我想与大家分享这个宝藏网站,请点击下方链接查看。 https://www.captainbed.cn/f1
鲜于言悠
2024/05/24
2290
Java输入与输出详解
ACM之Java输入输出[通俗易懂]
2. 在有些OJ系统上,即便是输出的末尾多了一个“ ”,程序可能会输出错误,所以在我看来好多OJ系统做的是非常之垃圾
全栈程序员站长
2022/08/24
1.2K0
java中Scanner的简单用法
为了获得所以数据,我们修改输入数据的分隔符,添加sc.useDelimiter(“\n”);
全栈程序员站长
2022/09/09
8190
java中Scanner的简单用法
递归什么的其实很简单
说起递归,大家都觉得很高大上,很神秘的东西,是计算机的精髓之一。其实我们从小就听过一个耳熟能详的递归故事:从前有座山,山里有座庙,庙里有个老和尚,正在给小和尚讲故事呢!故事是什么呢?“从前有座山,山里有座庙,庙里有个老和尚,正在给小和尚讲故事呢!故事是什么呢?‘从前有座山,山里有座庙,庙里有个老和尚,正在给小和尚讲故事呢!故事是什么呢?……’”中国文化果然博大精深,一个小故事里蕴含了如此深奥的秘密。(这不是复读机么。。。
zhanyd
2022/05/16
3850
递归什么的其实很简单
Java的输入与输出
GeekLiHua
2025/01/21
4390
一文读懂递归算法—程序员必会算法之一
今天我们来讲讲递归算法,递归在我们日常工作中是比较常见且常用的算法,面试中面试官也经常会让我们手写递归算法。由此可见递归算法的重要性。
公众号 IT老哥
2020/09/16
6890
一文读懂递归算法—程序员必会算法之一
java基本输入语句_java键盘输入语句
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
全栈程序员站长
2022/09/29
2K0
Java中next()和nextLine()的区别(为什么nextLine()输入回车没显示)
运行,输入2,然后点击回车,此时代码直接会运行结束。str无法接受任何字符串(在我们眼中宛如直接跳过了该条语句一样)。
VIBE
2022/12/02
1.6K0
相关推荐
《JavaSE-习题篇二》之七个题目,十六张图,让你不惧递归。
更多 >
交个朋友
加入腾讯云官网粉丝站
双11活动抢先看 更有社群专属礼券掉落
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验