Java益智小代码—递归和循环分析

2024-08-29 14:08

本文主要是介绍Java益智小代码—递归和循环分析,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一:递归和循环

        递归:程序调用自身的编程技巧称为递归。

        循环:for语句或者for each语句实现。

        递归是我们初学程序常常接触的小问题。麻雀虽小,可是深入理解它还是大有学问。

        比如,请用程序计算 n!。首先我们应该先要知道 n!是什么;如 5!=5 * 4 * 3 * 2 * 1,3!= 3 * 2 * 1等等。按照上面的思路,n!= n * (n-1) * (n-2) * (n-3) * (n-4) *.....* 3 * 2 * 1;我们最直白的思想是非递归运用for循环进行阶乘进行求解。

import java.util.Scanner;public class Resursion01 {public static void main(String[] args) {System.out.println("请输入您想阶乘的数:");Scanner sc1 = new Scanner(System.in);int n = sc1.nextInt();if(n < 0){System.out.println("对不起您输入的数不合法!");return;}int sum = 1;for(int i = n; i > 0; i--){sum *= i;}System.out.println(n+"! = "+sum);}
}
        上面的程序时间复杂度为O(n);空间复杂度比较小。(注:因为sum定义为int型,故进行阶乘的数不要太大,容易溢出)

        本节程序讲的是递归,我们当然要用递归去解决一下这个问题。递归就是自己调用自己,但是有判断条件,并且当判断量大于终止条件就一直向下递归,当不满足终止条件时,它就向上递归返回值。最终给出我们想要的结果。故运用递归进行阶乘的代码为:

import java.util.Scanner;public class Resursion02 {public static void main(String[] args) {System.out.println("请输入向进行阶乘的数N:");Scanner sc = new Scanner(System.in);int n = sc.nextInt();if(n < 0){System.out.println("输入的N不合法.");return ;}int sum = f(n);System.out.println(sum);}public static int f(int n){if(n == 1){return 1;}else{return n * f(n-1); }}
}

        这个程序的空间复杂度和时间复杂度都很大,所以我们在运用递归时一定要注意。(注:因为sum定义为int型,故进行阶乘的数不要太大,容易溢出)

        n!的阶乘程序递归图为:


二:递归和循环分析

        递归的优劣

        递归的优势:递归的程序代码简单易读,在实现某些算法时还是有特定的优势:比如用递归实现数据结构中的Tree遍历前序遍历(先遍历根节点,再遍历左子树,最后遍历右子树)、中序遍历(先遍历左子树,再遍历根节点,最后遍历右子树)、后续遍历(先遍历左子树,再遍历右子树,最后遍历根节点);

        递归的劣势:递归是程序本身调用自身,函数调用自身是有时间和空间消耗的(栈空间的消耗),在递归每一次调用自身这个函数时,都需要在内存中分配一定的空间以保存参数、临时变量以及返回地址等信息,而在栈中数据的出栈和入栈都是有时间需求的,故运用递归时会大大降低程序的运行效率,尤其是当递归基数比较大时,效率尤为明显,故在一般的开发中不会运用递归。

        循环的优劣:优势,重复执行一些步骤,执行完的就释放空间,一直到一个终止条件,故循环的空间复杂度比较低一些。

这篇关于Java益智小代码—递归和循环分析的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1118079

相关文章

Spring Boot + MyBatis Plus 高效开发实战从入门到进阶优化(推荐)

《SpringBoot+MyBatisPlus高效开发实战从入门到进阶优化(推荐)》本文将详细介绍SpringBoot+MyBatisPlus的完整开发流程,并深入剖析分页查询、批量操作、动... 目录Spring Boot + MyBATis Plus 高效开发实战:从入门到进阶优化1. MyBatis

SpringCloud动态配置注解@RefreshScope与@Component的深度解析

《SpringCloud动态配置注解@RefreshScope与@Component的深度解析》在现代微服务架构中,动态配置管理是一个关键需求,本文将为大家介绍SpringCloud中相关的注解@Re... 目录引言1. @RefreshScope 的作用与原理1.1 什么是 @RefreshScope1.

Java并发编程必备之Synchronized关键字深入解析

《Java并发编程必备之Synchronized关键字深入解析》本文我们深入探索了Java中的Synchronized关键字,包括其互斥性和可重入性的特性,文章详细介绍了Synchronized的三种... 目录一、前言二、Synchronized关键字2.1 Synchronized的特性1. 互斥2.

Spring Boot 配置文件之类型、加载顺序与最佳实践记录

《SpringBoot配置文件之类型、加载顺序与最佳实践记录》SpringBoot的配置文件是灵活且强大的工具,通过合理的配置管理,可以让应用开发和部署更加高效,无论是简单的属性配置,还是复杂... 目录Spring Boot 配置文件详解一、Spring Boot 配置文件类型1.1 applicatio

Java中StopWatch的使用示例详解

《Java中StopWatch的使用示例详解》stopWatch是org.springframework.util包下的一个工具类,使用它可直观的输出代码执行耗时,以及执行时间百分比,这篇文章主要介绍... 目录stopWatch 是org.springframework.util 包下的一个工具类,使用它

Java进行文件格式校验的方案详解

《Java进行文件格式校验的方案详解》这篇文章主要为大家详细介绍了Java中进行文件格式校验的相关方案,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、背景异常现象原因排查用户的无心之过二、解决方案Magandroidic Number判断主流检测库对比Tika的使用区分zip

Java实现时间与字符串互相转换详解

《Java实现时间与字符串互相转换详解》这篇文章主要为大家详细介绍了Java中实现时间与字符串互相转换的相关方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、日期格式化为字符串(一)使用预定义格式(二)自定义格式二、字符串解析为日期(一)解析ISO格式字符串(二)解析自定义

Java使用Curator进行ZooKeeper操作的详细教程

《Java使用Curator进行ZooKeeper操作的详细教程》ApacheCurator是一个基于ZooKeeper的Java客户端库,它极大地简化了使用ZooKeeper的开发工作,在分布式系统... 目录1、简述2、核心功能2.1 CuratorFramework2.2 Recipes3、示例实践3

Springboot处理跨域的实现方式(附Demo)

《Springboot处理跨域的实现方式(附Demo)》:本文主要介绍Springboot处理跨域的实现方式(附Demo),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不... 目录Springboot处理跨域的方式1. 基本知识2. @CrossOrigin3. 全局跨域设置4.

springboot security使用jwt认证方式

《springbootsecurity使用jwt认证方式》:本文主要介绍springbootsecurity使用jwt认证方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录前言代码示例依赖定义mapper定义用户信息的实体beansecurity相关的类提供登录接口测试提供一