深入理解 Java 方法重载与递归应用

Java 方法重载

方法重载 允许在同一个类中定义多个具有相同名称的方法,但 参数列表 必须不同。

语法:

returnType methodName(parameter1, parameter2, ..., parameterN) {// 方法体
}

示例:

public class Main {// 重载 add 方法,支持 int 和 double 类型参数static int add(int x, int y) {return x + y;}static double add(double x, double y) {return x + y;}public static void main(String[] args) {int sum1 = add(10, 20);double sum2 = add(3.14, 1.618);System.out.println("int: " + sum1);System.out.println("double: " + sum2);}
}

输出:

int: 30
double: 4.758

解释:

  1. 该示例中定义了两个 add 方法:
  • 一个接受两个 int 型参数并返回 int 型结果。
  • 另一个接受两个 double 型参数并返回 double 型结果。
  1. 在 main 方法中,我们分别调用了两个 add 方法并打印了结果。

重载的好处:

  • 可以使代码更加简洁易读。
  • 可以提高代码的可重用性。

重载的注意事项:

  • 方法的返回值类型可以不同。
  • 方法的访问权限不能不同。
  • 方法不能声明为 static 或 final。

总结

  • 方法重载允许在同一个类中定义多个具有相同名称的方法,但参数列表必须不同。
  • 重载可以使代码更加简洁易读,提高代码的可重用性。
  • 重载时需要注意返回值类型、访问权限、static 和 final 修饰符等限制。

Java 递归

递归 是一种让函数调用自身的技术。它提供了一种将复杂问题分解为简单问题的方法,这样更容易解决。

理解递归

递归可能有点难以理解。理解它的最好方法是通过实验来了解它是如何工作的。

递归示例

将两个数字相加很容易,但将一系列数字相加更复杂。在下面的示例中,使用递归通过将其分解为添加两个数字的简单任务来将一系列数字相加:

public class Main {public static void main(String[] args) {int result = sum(10);System.out.println(result);}public static int sum(int k) {if (k > 0) {return k + sum(k - 1);} else {return 0;}}
}

示例解释

  • 当调用 sum() 函数时,它将参数 k 添加到所有小于 k 的数字的和并返回结果。
  • 当 k 变为 0 时,函数只返回 0。
  • 运行时,程序按照以下步骤执行:
10 + sum(9)
10 + ( 9 + sum(8) )
10 + ( 9 + ( 8 + sum(7) ) )
...
10 + 9 + 8 + 7 + 6 + 5 + 4 + 3 + 2 + 1 + sum(0)
10 + 9 + 8 + 7 + 6 + 5 + 4 + 3 + 2 + 1 + 0
  • 由于当 k 为 0 时函数不再调用自身,程序在此停止并返回结果。

停止条件

就像循环可能陷入无限循环问题一样,递归函数可能陷入无限递归问题。无限递归是指函数永远不停止调用自身。每个递归函数都应该有一个 停止条件,即函数停止调用自身的条件。

停止条件示例

在前面的示例中,停止条件是参数 k 变为 0 时。

另一个停止条件示例

在这个例子中,函数将在开始和结束之间的一系列数字相加。这个递归函数的停止条件是当 end 不大于 start 时:

public class Main {public static void main(String[] args) {int result = sum(5, 10);System.out.println(result);}public static int sum(int start, int end) {if (end > start) {return end + sum(start, end - 1);} else {return end;}}
}

递归的注意事项

  • 开发人员在使用递归时应非常小心,因为很容易陷入编写永远不会终止的函数或使用大量内存或处理器资源的函数。
  • 然而,正确编写时,递归可以是一种非常高效和数学上优雅的编程方法。

递归的应用场景

递归可以用于解决许多不同类型的编程问题,例如:

  • 计算阶乘
  • 计算斐波那契数列
  • 遍历树形结构
  • 解析数学表达式
  • 生成各种图形

学习递归

  • 递归是一个重要的编程概念,学习它可以帮助你解决更复杂的问题。
  • 有许多资源可以帮助你学习递归,例如书籍、网站和在线教程。
  • 通过练习,你将能够更好地理

最后

看完如果觉得有帮助,欢迎 点赞、收藏、关注

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/729531.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

信号处理--使用CNN+LSTM实现单通道脑电信号EEG的睡眠分期评估

目录 背景 亮点 环境配置 数据 方法 结果 代码获取 参考文献 背景 睡眠对人体健康很重要。监测人体的睡眠分期对于人体健康和医疗具有重要意义。 亮点 架构在第一层使用两个具有不同滤波器大小的 CNN 和双向 LSTM。 CNN 可以被训练来学习滤波器,以从原始…

redis缓存(穿透, 雪崩, 击穿, 数据不一致, 数据并发竞争 ), 分布式锁(watch乐观锁, setnx, redission)

redis的watch缓存机制 WATCH 机制原理: WATCH 机制:使用 WATCH 监视一个或多个 key , 跟踪 key 的 value 修改情况,如果有key 的 value 值在事务 EXEC 执行之前被修改了,整个事务被取消。EXEC 返回提示信息,表示 事务已…

JavaEE面试题

一、String面试题 1、String s1 "123"; 和 String s2 new String("123");的区别 在Java中,"String s1 "123";"和"String s2 new String("123");"这两行代码有一些重要的区别: "…

Linux安装,配置,启动HBase

Linux安装,配置,启动HBase 一、HBase安装,配置 1、下载HBase安装包 Hbase官方下载地址: http://archive.apache.org/dist/hbase 选择相应的版本点击下载,这里以2.3.5为例 # linux可以通过wget命令下载 wget https://archive…

Windows11安装FFmpeg最新版本

打开终端: 输入 winget install ffmpeg 然后输入 Y 回车后出现如下图: 正在下载FFmpeg 6.1 安装成功 测试

C++知识点总结(23):高级模拟算法真题 ★★★☆☆《骰子游戏》

骰子游戏 1. 审题 題目描述 E r i c Eric Eric 最近在澳门旅游,澳门游乐场有这样一个骰子游戏,他们使用三颗六面骰子,游戏规则如下:点数的优先级是 6 6 6、 5 5 5、 4 4 4、 3 3 3、 2 2 2、 1 1 1,当三个骰子的点数…

STM32CubeIDE基础学习-STM32CubeIDE软件配置下载器方法

STM32CubeIDE基础学习-STM32CubeIDE软件配置下载器方法 文章目录 STM32CubeIDE基础学习-STM32CubeIDE软件配置下载器方法前言第1章 配置ST-LINK下载器第2章 配置DAP下载器总结 前言 这个软件编译完之后,可以使用下载器进行在线下载程序或仿真调试程序,也…

050-WEB攻防-PHP应用文件包含LFIRFI伪协议编码算法无文件利用黑白盒

050-WEB攻防-PHP应用&文件包含&LFI&RFI&伪协议编码算法&无文件利用&黑白盒 #知识点: 1、文件包含-原理&分类&危害-LFI&RFI 2、文件包含-利用-黑白盒&无文件&伪协议 演示案例: ➢文件包含-原理&分类&am…

设计模式(工厂模式)

设计模式(工厂模式) 一、工厂模式介绍 在工厂模式中,父类决定生成示例的方式,但不决定所要生成的具体的类,具体的处理部分交给子类负责。这样就可以将生成示例的框架和生成示例的类解耦。 二、示例程序 以下示例程…

力扣-数组题

1. 两数之和 找出map中是否有target-nums[i]&#xff0c; class Solution { public:vector<int> twoSum(vector<int>& nums, int target) {unordered_map<int, int> hash;for(int i 0 ;i < nums.size(); i){if(hash.find(target - nums[i]) ! hash…

MongoDB安装教程(附带安装包)

目录 解压安装包 傻瓜式安装 选择安装目录 安装完成 启动验证 验证成功 解压安装包 选择所需要的进行安装 傻瓜式安装 选择安装目录 安装完成 启动验证 mongod --dbpathD:\mongodb\data\db 验证成功

VUE_自适应布局lib-flexible+postcss-pxtorem、lib-flexible + postcss-px2rem,nuxt页面自适配

lib-flexible postcss-pxtorem适配 我采用的是flexable.js和postcss-pxtorem。我一开始用的是postcss-px2rem后来发现和nuxt引入公共css的时候发生了冲突所以改用了postcss-pxtorem。 安装依赖 npm i lib-flexible -S npm install postcss-pxtorem --save 1、lib-flexible.…

FreeRTOS学习笔记——列表和列表项及其API函数讲解

目录 精华总结&#xff1a; 列表和列表项 架构脑图&#xff1a; 列表和列表项的简介 列表的结构 列表项 迷你列表项 列表和列表项的关系 FreeRTOS 列表和列表项相关 API 函数 架构脑图&#xff1a; 列表和列表项相关 API 函数 函数 vListInitialise() 函数 vListIni…

IR 召回测试数据集(中文测试集)——T2Ranking

文章排名包括两个阶段&#xff1a;文章检索和文章重排序&#xff0c;这对信息检索&#xff08;IR&#xff09;领域的学术界和业界来说都是重要而具有挑战性的课题。然而&#xff0c;常用的文章排名数据集通常集中在英语语言上。对于非英语场景&#xff0c;如中文&#xff0c;现…

云犀首款AI直播调参大模型重磅发布,智能破解直播三大难!

3月7日晚&#xff0c;云犀重磅发布首款AI大模型——云犀墨子AI直播调参大模型&#xff01;据悉云犀墨子是一款懂直播的调参大模型&#xff0c;这项技术深度融合了机器学习、计算机视觉以及进步的图像处理算法&#xff0c;赋予直播间画面AI智能调控能力。 此次云犀墨子AI直播调参…

一文完全掌握富文本编辑器TinyMCE

一、安装和引入 TinyMCE 是主流富文本编辑器&#xff0c;功能非常全&#xff0c;你需要的大多数功能它都支持&#xff0c;类似在线版的 Word。但它的优势也恰恰是它的劣势&#xff0c;如此之多的功能都放上来导致整个编辑器非常重&#xff0c;如果只是需要简单功能&#xff0c…

Imagination大学计划 rv-fpga实验安装教程及注意事项

1. 实验环境安装 1.1 vivado 2019.2 网盘链接&#xff1a;Vivado_2019.2.tar.gz_免费高速下载|百度网盘-分享无限制 (baidu.com) 安装教程&#xff1a; 网盘中vivado文件夹下载到本地后解压打开&#xff0c;导航到下图&#xff0c;打开xsetup.exe文件。如果打开后有小弹窗直接…

论文阅读之Multimodal Chain-of-Thought Reasoning in Language Models

文章目录 简介摘要引言多模态思维链推理的挑战多模态CoT框架多模态CoT模型架构细节编码模块融合模块解码模块 实验结果总结 简介 本文主要对2023一篇论文《Multimodal Chain-of-Thought Reasoning in Language Models》主要内容进行介绍。 摘要 大型语言模型&#xff08;LLM…

重生奇迹mu战士大师技能加点怎么加

1、在重生奇迹MU中&#xff0c;战士大师的技能加点需要根据个人的游戏风格和需求来决定。一般来说&#xff0c;战士大师可以优先加点力量和体力&#xff0c;以增加攻击和生存能力。同时&#xff0c;可以适当加点敏捷来提高闪避和命中率。 2、在技能方面&#xff0c;可以根据个人…

深入剖析 Java 类属性与类方法的应用

Java 类属性 Java 类属性&#xff0c;也称为字段&#xff0c;是类中的变量。它们用于存储与类相关的数据。 创建类属性 在类定义中声明属性&#xff1a; public class Main {int x; // 属性String name; // 属性 }访问类属性 使用点语法访问对象的属性&#xff1a; Main …