首页 > 编程语言 >深入理解 Java 方法重载与递归应用

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

时间:2024-02-19 21:34:37浏览次数:23  
标签:Java 递归 int double sum static 重载

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

解释:

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

重载的好处:

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

重载的注意事项:

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

总结

  • 方法重载允许在同一个类中定义多个具有相同名称的方法,但参数列表必须不同。
  • 重载可以使代码更加简洁易读,提高代码的可重用性。
  • 重载时需要注意返回值类型、访问权限、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;
    }
  }
}

递归的注意事项

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

递归的应用场景

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

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

学习递归

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

最后

为了方便其他设备和平台的小伙伴观看往期文章:

微信公众号搜索:Let us Coding,关注后即可获取最新文章推送

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

标签:Java,递归,int,double,sum,static,重载
From: https://www.cnblogs.com/xiaowange/p/18022001

相关文章

  • java中file转字符串,字符串输出为文件
     读取文件转为字符串: //输入文件File类型,输出字符串 publicstaticStringfileToString(Filefile){ InputStreamis=null; ByteArrayOutputStreambos=newByteArrayOutputStream(); byte[]buffer=newbyte[1024]; inttemp=-1; try{ is=newFi......
  • JAVA基础-理解重载和重写
    1.Java的方法重载(Overload):就是在类中可以创建多个方法,它们具有相同的名字,但具有不同的参数和不同的定义。也就是说在一个类中,同名的方法如果有不同的参数列表(参数类型不同、参数个数不同甚至是参数顺序不同)则视为重载。同时,重载对返回类型没有要求,可以相同也可以不同,但不能通......
  • JavaScript 内置 Number 类型在处理浮点数时的精度问题 是如何造成的?
    JavaScript内置的Number类型在处理浮点数时的精度问题主要是由以下原因造成的:IEEE754浮点数标准:JavaScript中的数字是基于IEEE754标准实现的双精度浮点数(64位),其中:最高1位为符号位(0表示正数,1表示负数)。接下来的11位用于存储指数部分(范围大约从-1022到1023)。剩余的......
  • java的getResource方法 总结一下 在Java中获取资源的时候,经常用到getResource和getRes
    java的getResource方法总结一下在Java中获取资源的时候,经常用到getResource和getResourceAsStream,本文总结一下这两种获取资源文件的路径差异1.前言在Java中获取资源的时候,经常用到getResource和getResourceAsStream,本文总结一下这两种获取资源文件的路径差异。2.Class.get......
  • Java版Flink(十二)底层函数 API(process function)
    一、概述之前的转化算子是无法访问事件的时间戳信息和水位线watermark,但是,在某些情况下,显得很重要。Flink提供了DataStreamAPI的Low-Level转化算子。比如说可以访问事件时间戳、watermark、以及注册定时器,还可以输出一些特定的事件,比如超时事件等。ProcessFunction用......
  • 洛谷题单指南-递推与递归-P1990 覆盖墙壁
    原题链接:https://www.luogu.com.cn/problem/P1990题意解读:用两种可旋转的形状铺满N*2的区域,求方案数,可以使用递推。解题思路:步骤1、设f[i]表示铺满i*2的区域的方案数根据要求,i*2区域最后一列有4种可能的铺法:如果采用图1铺法,则有f[i]=f[i-1]如果采用图2铺法,则有f[i]=f......
  • 熟悉又陌生的JavaWeb 第0天
    传送门JavaWeb程序设计不满足于Java基础的窗口命令行程序,那来试试网站吧于是便有了JavaWeb印象中的大学教材应该是这本书,不过无所谓了,大同小异,教的内容其实差不多看看教科书的目录JavaWeb开发环境配置B/S结构服务器安装IDE安装第一个Web项目课后习题HTML基础......
  • Json 递归解析算法笔记
    需求:最近需要处理包含多层的Json字符串解析的问题,比如需要将所有的键值对的值替换,或者将键值对的键替换,包括嵌套对象里面的。大致知道需要使用递归来操作,先记录大致步骤吧。思路:写好一个固定的函数专门处理替换步骤;在这个函数内分别判断值是数组,还是对象,还是值(值走上面的递......
  • Flink入门之Flink程序开发步骤(java语言)
    Flink入门之Flink程序开发步骤(java语言)文章目录(0)开发程序所需依赖(1)获取执行环境(2)加载/创建数据源(3)数据转换处理(4)处理后数据放置/输出(5)执行计算程序(6)完整示例注:本篇章的flink学习均是基于java开发语言我们如果要使用flink进行计算开发,一个完整的开发步骤是怎样的呢?前......
  • 前端知识回顾概览--JavaScript 高级
     掌握JS语言,针对闭包、原型链等有深入理解对typescript静态化工具熟练掌握精通常见设计模式了解函数式编程 1.this指针/闭包/作用域this指针详解闭包的概念及应用场景作用域(全局作用域/函数作用域)默认绑定、显式绑定、隐式绑定存储空间、执行上下文2.面向对象编......