递归java程序_JAVA编程基础之递归结构

递归结构

递归是一种常见的解决问题的方法,即把问题逐渐简单化。 递归的基本思想就是 自己调用自己 ”,一个使用递归技术的方法将会直接或者间接的调用自己。利用递归可以用简单的程序来解决一些复杂的问题。比如:大多数排序使用的就是递归算法。

递归结构包括两个部分:

定义递归头。解答:什么时候不调用自身方法。如果没有头,将陷入死循环。

递归体。解答:什么时候需要调用自身方法。

public static void print(int i) { System.out.println(i); if(i==10){ //递归头 return; //提前结束方法 } print(++i); //递归 } public static void main(String[] args) { print(1); //打印1~10之间的数据 }

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-MWfwEeC3-1604288171968)(/5b6fac208b0ad.jpg)]

这个图片很好的诠释了递归,我们可以使用代码实现打印**吓得我抱起了抱着抱着抱着我的小鲤鱼的我的我的我**

public static void recursion(int i) { System.out.println("抱着"); if (i==0) { //临界条件 System.out.println("我的小鲤鱼"); } else { recursion(--i); // 递归调用 } System.out.println("的我"); } public static void main(String[] args) { System.out.println("吓得我抱起了"); recursion(2); }

递归的缺陷:

简单的程序是递归的优点之一。但是递归调用会占用大量的系统堆栈,内存耗用多,在递归调用层次多时速度要比循环慢的多。所以再使用时要慎重。

**注意:**任何可用递归解决的问题也能使用迭代解决。但递归方法可以更加自然地反映问题,并且易于理解和调试,并且不强调效率问题时,可以采用递归;

在要求高性能的情况下尽量避免使用递归,递归调用既花时间又耗内存。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Java语言程序设计与数据结构(基础篇)是一本介绍Java编程语言和数据结构基础知识的教材。本书主要包括Java语言基础、面向对象编程、数据结构、算法设计等方面的内容。通过学习本书,读者可以掌握Java编程语言的基本语法和面向对象编程的思想,了解常用的数据结构和算法设计方法,并能够运用所学知识进行程序设计和开发。本书适合初学者和有一定编程基础的读者阅读。 ### 回答2: Java语言程序设计与数据结构(基础篇)是一门综合性的课程,旨在培养学生对Java语言的理解与应用能力,同时深入了解和掌握数据结构的基本概念和操作。 在这门课程中,学生将学习Java编程语言的基本语法和面向对象编程的思想,包括类、对象、继承、封装等概念。通过实际编程练习,学生将掌握Java编程的基本技巧和方法。 除了Java语言的基础知识,这门课程还会涉及数据结构的相关内容。学生将学习常见的数据结构,如线性表、栈、队列和树等,以及它们的特点和操作。同时,学生还将学习数据结构的算法和性能分析方法,了解不同数据结构之间的比较和选择。 在学习过程中,学生需要通过编写实际的Java程序,加深对所学知识的理解和应用。通过实践,学生将逐步掌握如何设计和实现数据结构的相关算法,以及如何利用这些数据结构解决实际问题。 总之,Java语言程序设计与数据结构(基础篇)是一门重要的课程,它为学生打下了良好的编程基础,培养了学生的编程思维和数据处理能力。在这门课程的学习中,学生将获得扎实的Java编程和数据结构的相关知识,为进一步深入学习和应用打下坚实的基础。 ### 回答3: Java语言程序设计与数据结构(基础篇)是一门关于Java编程语言和基本数据结构的课程。在这门课程中,学生将学习如何使用Java语言来编写程序,并了解不同的数据结构以及如何在Java中实现它们。 在这门课程中,学生将学习Java的基本语法、控制流程和面向对象编程的概念。他们将学习如何定义类和对象,并实现封装、继承和多态等面向对象的特性。学生还将研究Java中的异常处理机制,并学习如何编写可重用的代码。 此外,在这门课程中,学生还将学习基本的数据结构,如数组、链表、栈和队列。他们将学习如何使用这些数据结构来解决实际问题,并学习如何分析算法的时间和空间复杂度。学生还将学习如何使用递归来解决问题,并研究常见的排序和搜索算法。 通过学习这门课程,学生将建立起良好的编程基础,并能够使用Java语言来解决实际问题。他们将学习如何设计和实现高效的算法,并理解数据结构在计算机科学中的重要性。这些知识将对他们今后的学习和职业生涯产生积极的影响。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值