0

0

不熟悉Java递归方法的代码

WBOY

WBOY

发布时间:2024-01-13 19:48:19

|

477人浏览过

|

来源于Excel办公网

转载

java代码不懂递归方法

java代码不懂递归方法

这也是个循环的方法 初学者可能难看懂...我解释一下

例如 那个fun()方法里面的参数是100吧 我把它改一下 改成2好吧

这个递归方法的目的是累加,和循环累加的结果相同,只是执行方式不同。

程序执行的过程如下:

立即学习Java免费学习笔记(深入)”;

当你传2进去时. 程序会执行else里面的内容

也就是return temp+fun(temp-1);

实际是返回的是:2+fun(2-1);

也就是: 2+fun(1) 把原来的那个参数3改为了2;

我开始说了吧 这是个累加的程序 所以把3提出来赋给 前面定义好的sum 所以现在的sum=2;

因为这是个递归的方法 所以接下来又要重复执行这个fun(int temp)方法 ;

只是现在的参数变成了1

所以 接下来程序会这样走 :

因为参数是1 所以会进入到if里面

所以会返回1;

所以现在的sum就应该是之前的sum加上现在的fun(1)返回的1

so.....now sum就应是:2+1=3;

我只是举了其中的两个数之间的循环 其他的98个数之间的循环也是这样的

总之递归就是一直调用自己 直到不能满足条件时就不会调用自己了

你看看吧 可能有点多 我想解释的更加清楚一点 之前我也遇到过 不过我没问过别人 没看懂或者是不懂的再问我.....

Java递归算法高收请进!用递归实现

作的挺好看的阿,能做出这样水准的界面,这个小问题应该难不到你吧。

这里的问题是:

1. 设计这个图的结构,最简单的就是用数组了。

2. 怎么枚举相连的节点。简单的说就是判断左上、右上、左、右、左下、右下的问题。

3. 怎么依次判断颜色相同问题,最简单的算法是淹没法。就是从上面6个方向开始找,找到下一个点后,就在从6个方向开始找。。。

大概的代码如下:

class Rabbit

{

final int D_UP_LEFT = 1 ;

final int D_UP_RIGHT = 2 ;

final int D_LEFT = 3 ;

final int D_RIGHT = 4 ;

final int D_DOWN_LEFT = 5 ;

final int D_DOWN_RIGHT = 6 ;

getColor () ;

getCloseRibbit (int direction)

{

... // 这里实现获取相邻指定方向兔子的函数

// 如果没有返回null .

}

int getColor () {}

List checkColor ()

{

ArrayList list = new ArrayList () ;

doCheckColor (list, this) ;

return list ;

}

void doCheckColor (List list, Rabbit r)

{

if (r.getColor () != this.getColor () || list.contains (r))

return ;

list.add (this) ;

for (int i = D_UP_LEFT ; i

{

Rabbit next = r.getCloseRibbit (i) ;

if (next != null)

next.doCheckColor (list, r) ;

}

}

}

结果的list就是你要的相同颜色的小兔子。

Okaaaay
Okaaaay

适用于所有人的AI文本和内容生成器

下载

JAVA如何使用递归方法实现从1到m中取nn

使用数组的递归:

public class Test12 {

static int M = 4;

static int N = 3;

static int[] a= new int[]{1,2,3,4};

static int[] b = new int[N];

public static void main(String[] args){

C(M,N);

}

static void C(int m,int n){

int i,j;

for(i=n;i

b[n-1] = i-1;

if(n>1)

C(i-1,n-1);

else {

for(j=0;j

System.out.print(a[b[j]] + " ");

System.out.println();

}

}

}

}

输出:

1 2 3

1 2 4

1 3 4

2 3 4

java实现递归运算n!输入n如果不是整型提示重新输

java 实现递归运算n!,输入n,如果不是整型,提示重新输...

port java.util.Scanner;

import java.util.regex.Matcher;

import java.util.regex.Pattern;

public class Test {

public int jiecheng(int num) {// 递归阶乘

if (num > 1)

return num * jiecheng(num - 1);

else if (num == 1)

return 1;

else

return 0;

}

public static void main(String[] args) {

Scanner sc = new Scanner(System.in);// 从键盘获取输入

String num = "";

Pattern p = Pattern.compile("\d+");// 正则表达式,匹配(1到N位)整数

Matcher m = null;

int k = 0;

while (true) {

System.out.print("请输入一个整数:");

num = sc.nextLine();// 获取一行输入

m = p.matcher(num);

if (m.matches()) {

k = Integer.valueOf(num);// 字符串转整数

break;

} else

System.out.println("不是整数,请重新输入!");

System.out.println();

}

System.out.println(new Test().jiecheng(k));// 调用阶乘的方法

}

}

喜居宝地千年旺 福照家门万事兴 喜迎新春

java速学教程(入门到精通)
java速学教程(入门到精通)

java怎么学习?java怎么入门?java在哪学?java怎么学才快?不用担心,这里为大家提供了java速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
c语言中null和NULL的区别
c语言中null和NULL的区别

c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

252

2023.09.22

java中null的用法
java中null的用法

在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

1049

2024.03.01

if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

846

2023.08.22

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

970

2023.08.02

int占多少字节
int占多少字节

int占4个字节,意味着一个int变量可以存储范围在-2,147,483,648到2,147,483,647之间的整数值,在某些情况下也可能是2个字节或8个字节,int是一种常用的数据类型,用于表示整数,需要根据具体情况选择合适的数据类型,以确保程序的正确性和性能。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

606

2024.08.29

c++怎么把double转成int
c++怎么把double转成int

本专题整合了 c++ double相关教程,阅读专题下面的文章了解更多详细内容。

294

2025.08.29

C++中int的含义
C++中int的含义

本专题整合了C++中int相关内容,阅读专题下面的文章了解更多详细内容。

212

2025.08.29

javascriptvoid(o)怎么解决
javascriptvoid(o)怎么解决

javascriptvoid(o)的解决办法:1、检查语法错误;2、确保正确的执行环境;3、检查其他代码的冲突;4、使用事件委托;5、使用其他绑定方式;6、检查外部资源等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

186

2023.11.23

JavaScript浏览器渲染机制与前端性能优化实践
JavaScript浏览器渲染机制与前端性能优化实践

本专题围绕 JavaScript 在浏览器中的执行与渲染机制展开,系统讲解 DOM 构建、CSSOM 解析、重排与重绘原理,以及关键渲染路径优化方法。内容涵盖事件循环机制、异步任务调度、资源加载优化、代码拆分与懒加载等性能优化策略。通过真实前端项目案例,帮助开发者理解浏览器底层工作原理,并掌握提升网页加载速度与交互体验的实用技巧。

23

2026.03.06

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号