当前位置:首页 > 文章列表 > 文章 > java教程 > 基于Java语言的递归运算实例分析

基于Java语言的递归运算实例分析

来源:亿速云 2024-04-08 08:09:36 0浏览 收藏

从现在开始,努力学习吧!本文《基于Java语言的递归运算实例分析》主要讲解了等等相关知识点,我会在golang学习网中持续更新相关的系列文章,欢迎大家关注并积极留言建议。下面就先一起来看一下本篇正文内容吧,希望能帮到你!

递归定义:一个方法在执行过程中调用自身, 就称为 "递归"。

递归的必要条件:

1. 将原问题划分成其子问题,注意:子问题必须要与原问题的解法相同。

2. 递归出口。

一、实例演示:递归求N的阶乘

public class fac {
    public static int factorial(int x){
        if(x<2){
            return 1;
        }
        else{
           return x * factorial(x-1);//递归调用本身
        }
    }
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        int n = sc.nextInt();
        System.out.println(factorial(n));
    }
}

递归过程分析:

本题假设我们想求解5的阶乘,我们可以看到我们从main函数里面输入一个数N,这里我们输入5,随即在我们的功能函数factorial接收到参数5,接着因为if里面的条件是x<2,不满足,所以执行我们的else里面的语句,我们发现是return x * factorial(x-1);我们输入的是5,所以即 return 5   *factorial(4);同理我们调用了本身这个factorial函数,传进去的参数是4,接着继续……,直到我们的参数变成1<2,那么这时递归的  “递” ,结束,开始我们的 “归”。

执行结果

函数开始, n = 5
函数开始, n = 4
函数开始, n = 3
函数开始, n = 2
函数开始, n = 1
函数结束, n = 1 ret = 1
函数结束, n = 2 ret = 2
函数结束, n = 3 ret = 6
函数结束, n = 4 ret = 24
函数结束, n = 5 ret = 120
ret = 120

运行结果:

基于Java语言的递归运算实例分析

二、 递归调用练习

递归求1+2+3+……10的和

public class result {
    public static int fun(int n){
        if(n==1){
            return 1;
        }
        return n+fun(n-1);
    }
    public static void main(String[] args) {
        Scanner scanner  = new Scanner(System.in);
        int n = scanner.nextInt();
        System.out.println(fun(n));
    }
}

递归的核心思想就是我们的递归体应该如何设计,本题我们想得到1+……10的和,来看我们的递归体如何设计的!

运行结果:

基于Java语言的递归运算实例分析

顺序打印一个数字的每一位

问题分析:比如我们想打印1234的每一位,那么打印出来应该就是1 2 3 4那么首先就是如何判断我们输入的数字是几位数,看下面的功能代码部分,设计非常的巧妙,通过是否n>9,是->我们递归调用本身传参数 “n/10”,打印的结果就是  n%10  这样肯定得到的就是我们的每一位数字!

public class print {
    public static void fun(int n){
        if(n>9){
            fun(n/10);
        }
        System.out.print(n%10+" ");
    }
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        int n = sc.nextInt();
        fun(n);
    }
}

运行结果:

基于Java语言的递归运算实例分析

返回一个数组成本身的数字之和

比如我们输入1234,输出就是1+2+3+4=10。

函数实现:

public class sum {
    public static int sumd(int num) {
        if (num < 10)
            return num;
        return num % 10 + sumd(num / 10);
    }
    public static void main(String[] args) {
        Scanner sc= new Scanner(System.in);
        int n = sc.nextInt();
        System.out.println(sumd(n));
    }
}

运行结果:

基于Java语言的递归运算实例分析

求解汉诺塔问题

定义:汉诺塔(Tower of Hanoi),又称河内塔,是一个源于印度古老传说的益智玩具。大梵天创造世界的时候做了三根金刚石柱子,在一根柱子上从下往上按照大小顺序摞着64片黄金圆盘。大梵天命令婆罗门把圆盘从下面开始按大小顺序重新摆放在另一根柱子上。并且规定,在小圆盘上不能放大圆盘,在三根柱子之间一次只能移动一个圆盘。

代码实现:

public class Hanio {
    public static void han(int n,char pos1,char pos2,char pos3){
        if(n==1){
            move(pos1,pos3);
            return;
        }
        han(n-1,pos1,pos3,pos2);
        move(pos1,pos3);
        han(n-1,pos2,pos1,pos3);
    }
    public static void move(char pos1,char pos2){
 
        System.out.println(pos1+"->"+pos2);
    }
    public static void main(String[] args) {
 
        han(3,'A','B','C');
    }
}

代码解读:通过定义我们可以了解到每次只能移动一个盘子,并且小盘子要放在大盘子上面,那么这里我们有A B C,三个圆柱,我们可以将其依次理解为:初始位置   跳板位置  目标位置,我们看函数部分,如果只有一个盘子我们直接从A->C 只需移动一步便可,那么>1的情况,这里我们假设要移动三个盘子,通过画图我们可以发现首先要将2个盘子移动到B圆柱再借助A移动到C盘,那么这里的第一次调用 han(n-1,pos1,pos3,pos2);我们便可以理解,下次递归将(n-1)作为盘子个数,pos1就是我们的起始位置,pos3就是我们的跳板位置,pos2就是我们的目标位置,因为首先我们将(n-1)个盘子放在了B(pos2)上,调用结束后,执行我们的move函数,输出我们这次的移动轨迹,下次调用就是han(n-1,pos2,pos1,pos3);同理,这个时候pos2就是我们的起始位置,pos1变成我们的跳板位置,最后pos3是我们的目标位置。

运行结果:(我们可以自己画图尝试一下看这个结果是否正确)

基于Java语言的递归运算实例分析

求斐波那契数列第N项

斐波那契数列指的是这样一个数列:1,1,2,3,5,8,13,21,34,55,89...这个数列从第3项开始,每一项都等于前两项之和。

那么,谈及递归的运算不得不提斐波那契数列这样的经典问题,下面就给大家展示一下Java语言的代码实现:

public class Fib {
    public static int Fibo(int n){
        if(n<=2){
            return 1;
        }
        else{
            return Fibo(n-1)+Fibo(n-2);
        }
    }
    public static void main(String[] args) {
        Scanner sc =new Scanner(System.in);
        int n = sc.nextInt();
        System.out.println(Fibo(n));
    }
}

代码分析:虽然这种递归方法很容易理解方便使用,但是我们发现在递归的过程中,如果我们要求斐波那契数列的前40项 50项的和,以40项为例我们首先需要求 39项 38项的结果,而要得到39项的和我们要求出38的项的结果和37项的结果,进而上个38项的结果我们需要在求一次,这样发现我们有很多次的重复计算,造成了很不必要的浪费,那么我们可以通过for循环的方式来减少代码冗余度。

优化代码:

public static int fib(int n) {
  int last2 = 1;
  int last1 = 1;
  int sum = 0;
  for (int i = 3; i <= n; i++) {
    sum = last1 + last2;
    last2 = last1;
    last1 =sum;
 }
  return sum;
}

运行结果:

基于Java语言的递归运算实例分析

到这里,我们也就讲完了《基于Java语言的递归运算实例分析》的内容了。个人认为,基础知识的学习和巩固,是为了更好的将其运用到项目中,欢迎关注golang学习网公众号,带你了解更多关于java的知识点!

版本声明
本文转载于:亿速云 如有侵犯,请联系study_golang@163.com删除
如何告诉 Go 编译器忽略未使用的变量?如何告诉 Go 编译器忽略未使用的变量?
上一篇
如何告诉 Go 编译器忽略未使用的变量?
Go 语言的静态类型解析
下一篇
Go 语言的静态类型解析
查看更多
最新文章
查看更多
课程推荐
  • 前端进阶之JavaScript设计模式
    前端进阶之JavaScript设计模式
    设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
    542次学习
  • GO语言核心编程课程
    GO语言核心编程课程
    本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
    508次学习
  • 简单聊聊mysql8与网络通信
    简单聊聊mysql8与网络通信
    如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
    497次学习
  • JavaScript正则表达式基础与实战
    JavaScript正则表达式基础与实战
    在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
    487次学习
  • 从零制作响应式网站—Grid布局
    从零制作响应式网站—Grid布局
    本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
    484次学习
查看更多
AI推荐
  • PPTFake答辩PPT生成器:一键生成高效专业的答辩PPT
    PPTFake答辩PPT生成器
    PPTFake答辩PPT生成器,专为答辩准备设计,极致高效生成PPT与自述稿。智能解析内容,提供多样模板,数据可视化,贴心配套服务,灵活自主编辑,降低制作门槛,适用于各类答辩场景。
    14次使用
  • SEO标题Lovart AI:全球首个设计领域AI智能体,实现全链路设计自动化
    Lovart
    SEO摘要探索Lovart AI,这款专注于设计领域的AI智能体,通过多模态模型集成和智能任务拆解,实现全链路设计自动化。无论是品牌全案设计、广告与视频制作,还是文创内容创作,Lovart AI都能满足您的需求,提升设计效率,降低成本。
    14次使用
  • 美图AI抠图:行业领先的智能图像处理技术,3秒出图,精准无误
    美图AI抠图
    美图AI抠图,依托CVPR 2024竞赛亚军技术,提供顶尖的图像处理解决方案。适用于证件照、商品、毛发等多场景,支持批量处理,3秒出图,零PS基础也能轻松操作,满足个人与商业需求。
    27次使用
  • SEO标题PetGPT:智能桌面宠物程序,结合AI对话的个性化陪伴工具
    PetGPT
    SEO摘要PetGPT 是一款基于 Python 和 PyQt 开发的智能桌面宠物程序,集成了 OpenAI 的 GPT 模型,提供上下文感知对话和主动聊天功能。用户可高度自定义宠物的外观和行为,支持插件热更新和二次开发。适用于需要陪伴和效率辅助的办公族、学生及 AI 技术爱好者。
    26次使用
  • 可图AI图片生成:快手可灵AI2.0引领图像创作新时代
    可图AI图片生成
    探索快手旗下可灵AI2.0发布的可图AI2.0图像生成大模型,体验从文本生成图像、图像编辑到风格转绘的全链路创作。了解其技术突破、功能创新及在广告、影视、非遗等领域的应用,领先于Midjourney、DALL-E等竞品。
    53次使用
微信登录更方便
  • 密码登录
  • 注册账号
登录即同意 用户协议隐私政策
返回登录
  • 重置密码