递归---Day29
递归的概述
递归:指在当前方法内自己调用自己的方式叫做递归
递归的分类:
1.直接递归称为方法自身调用自己。
2.间接递归可以用A方法调用B方法,用B方法调用C方法,用C方法调用A方法。
递归的注意事项
递归一定要有限定条件,保证递归能够停止下来,否则会出现死循环,导致发生栈内存溢出。 在递归中虽然有限定条件,但是递归次数不能太多。否则也会发生栈内存溢出。 构造方法,禁止递归
package demosummary.recursive;
public class RecursiveDemo1 {
public static void main(String[] args) {
//调用a方法
a(1);
//调用b方法
b();
}
private static void a(int i) {
System.out.println(i);
//添加一个条件避免发生内存溢出现象
if (i == 10) {
return;
}
a(++i);
}
//没有限制条件,会发生内存溢出现象
private static void b() {
System.out.println("b方法");
b();
}
}
递归累加求和
package demosummary.recursive; /**
* 计算1~n的和
* 分析:
* num的累和 = num + (num-1)的累和,所以可以把累和的操作定义成一个方法,递归调用
*/
public class RecursiveSum {
public static void main(String[] args) {
int sum = getSum(5);
System.out.println(sum);
} private static int getSum(int num) {
if (num == 1) {
return 1;
}
return num+getSum(num -1);
}
}
递归求阶乘(同求和一样解法)
package demosummary.recursive;
public class RecursiveFactorial {
public static void main(String[] args) {
int sum = getSum(5);
System.out.println(sum);
}
private static int getSum(int num) {
//当num=1时,停止递归,防止发生内存溢出现象
if (num == 1) {
return 1;
}
return num * getSum(num - 1);
}
}
递归打印多级目录
package demosummary.recursive;
import java.io.File;
public class RecursivePrintDir {
public static void main(String[] args) {
//创建File对象
File file = new File(".//filter");
//调用打印方法
printDir(file);
}
private static void printDir(File dir) {
//获取目录的集合
File[] files = dir.listFiles();
//循环打印目录
for (File file : files) {
if (file.isFile()) {//判断是否为文件
System.out.println("文件的路径:" + file.getAbsolutePath());
} else {//判断是否为目录
System.out.println("目录的路径:" + file.getAbsolutePath());
//是目录则继续往下打印
printDir(file);
}
}
}
}
递归---Day29的更多相关文章
- .NET 基础 一步步 一幕幕[面向对象之方法、方法的重载、方法的重写、方法的递归]
方法.方法的重载.方法的重写.方法的递归 方法: 将一堆代码进行重用的一种机制. 语法: [访问修饰符] 返回类型 <方法名>(参数列表){ 方法主体: } 返回值类型:如果不需要写返回值 ...
- 算法笔记_013:汉诺塔问题(Java递归法和非递归法)
目录 1 问题描述 2 解决方案 2.1 递归法 2.2 非递归法 1 问题描述 Simulate the movement of the Towers of Hanoi Puzzle; Bonus ...
- Android 算法 关于递归和二分法的小算法
// 1. 实现一个函数,在一个有序整型数组中二分查找出指定的值,找到则返回该值的位置,找不到返回 -1. package demo; public class Mytest { public st ...
- 二叉树的递归实现(java)
这里演示的二叉树为3层. 递归实现,先构造出一个root节点,先判断左子节点是否为空,为空则构造左子节点,否则进入下一步判断右子节点是否为空,为空则构造右子节点. 利用层数控制迭代次数. 依次递归第二 ...
- 递归实现n(经典的8皇后问题)皇后的问题
问题描述:八皇后问题是一个以国际象棋为背景的问题:如何能够在8×8的国际象棋棋盘上放置八个皇后, 使得任何一个皇后都无法直接吃掉其他的皇后?为了达到此目的,任两个皇后都不能处于同一条横行.纵行或斜线上 ...
- C语言用分别用递归和循环求数字的阶乘的方法
以下代码均为 自己 实现,嘻嘻! 参考文章:http://blog.csdn.net/talk_8/article/details/46289683 循环法 int CalFactorial(int ...
- C#递归解决汉诺塔问题(Hanoi)
using System;using System.Collections.Generic;using System.Linq;using System.Text; namespace MyExamp ...
- Java之递归求和的两张方法
方法一: package com.smbea.demo; public class Student { private int sum = 0; /** * 递归求和 * @param num */ ...
- C#语言基础——递归
递归 一.概念conception: 函数体内调用本函数自身,直到符合某一条件不再继续调用. 二.应满足条件factor: (1)有反复执行的过程(调用自身): (2)有跳出反复执行过程的条件(函数出 ...
随机推荐
- 201871010107-公海瑜《面向对象程序设计(java)》第十三周学习总结
201871010107-公海瑜<面向对象程序设计(java)>第十三周学习总结 项目 内容 这个作业属于哪个课程 ...
- 代码审计-extract变量覆盖
<?php $flag='xxx'; extract($_GET); if(isset($shiyan)) { $content=trim(file_get_contents($flag)); ...
- java web问题总结
1.java web上传附图页面空,无返回 原因:前端页面与后台端口不一致,无页面可返回 2.上传excel导入数据时,只能导入第一条,后面的数据无法导入,缓存设置过小.
- day30_8.9 操作系统与并发编程
一.操作系统相关 1.手工操作 1946年第一台计算机诞生--20世纪50年代中期,计算机工作还在采用手工操作方式.此时还没有操作系统的概念. 这时候的计算机是由人为将穿孔的纸带装入输入机,控制台获取 ...
- 实战接口开发:python + flask + mysql + redis(根据反馈,持续细化更新。。。)
前言 自动化已经成为测试的必备技能之一了,所以,很多想跳槽的测试朋友都在自学,特别是最实用的接口自动化, 但是很多人因为没有可以练手的项目而苦恼,最终导致缺乏实战经验,其实,完全可以自己开发个简单项目 ...
- 快速安装Rainbond——开源企业级Paas平台
快速安装Rainbond--开源企业级Paas平台 参考:https://www.rainbond.com/docs/user-operations/install/online_install/ R ...
- 生鲜超市项目错误及解决办法(安装mysqlclient)
错误1:安装Mysqlclient D:\Mxshop>pip install mysqlclient- 1.4.4-cp27-cp27m-win32 报错: ERROR: Could not ...
- 关于matlab tfdata的用法
加上'v',可以让输出的值由元胞数组改为数组直接输出:举个例子:h = tf([1 1],[1 2 5]);[num,den] = tfdata(h)可以看出输出的num和den为元胞数组的形式无 ...
- 其它 dev是什么意思
原文:https://blog.csdn.net/zsl131557/article/details/80886114 原文:https://blog.csdn.net/LYmahang123/art ...
- jquery.pagination.js的使用
html页面 //要显示内容表格 <table id="gifts"> <tr class='first'> <th>时间</th> ...