网创优客建站品牌官网
为成都网站建设公司企业提供高品质网站建设
热线:028-86922220
成都专业网站建设公司

定制建站费用3500元

符合中小企业对网站设计、功能常规化式的企业展示型网站建设

成都品牌网站建设

品牌网站建设费用6000元

本套餐主要针对企业品牌型网站、中高端设计、前端互动体验...

成都商城网站建设

商城网站建设费用8000元

商城网站建设因基本功能的需求不同费用上面也有很大的差别...

成都微信网站建设

手机微信网站建站3000元

手机微信网站开发、微信官网、微信商城网站...

建站知识

当前位置:首页 > 建站知识

Java递归基础与递归的示例分析

小编给大家分享一下Java递归基础与递归的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

让客户满意是我们工作的目标,不断超越客户的期望值来自于我们对这个行业的热爱。我们立志把好的技术通过有效、简单的方式提供给客户,将通过不懈努力成为客户在信息化领域值得信任、有价值的长期合作伙伴,公司提供的服务项目有:申请域名网站空间、营销软件、网站建设、宾阳网站维护、网站推广。

1.什么是递归

本质上,将原来的问题,转化为更小的同一问题

2.例子分析

假设我们需要对数组进行求和操作(只是为了更好理解递归程序)

要求如下:求解从索引为0到n-1的数组元素和。

分析:

为了能求解从索引为0到n-1的数组元素和,可以分解为第0个数加上索引从1到n-1的数组元素和,如下:

Java递归基础与递归的示例分析

此时求解索引从1到n-1的数组元素和的规模比求解从索引为0到n-1的数组元素和要少一个数以此类推,如下:

Java递归基础与递归的示例分析

.......

最基本问题:

Java递归基础与递归的示例分析

 3.代码实现本例操作

新建一个package 包名为 Recursion,然后在该包下新建一个SumArray类,相关代码如下

package Recursion;

public class SumArray {
  //调用
  public static int sum(int[] arr) {
    return sum(arr, 0);//0 索引从0开始
  }

  //递归实现数组相加
  //l表示索引

  private static int sum(int[] arr, int l) {
    if (l == arr.length)
      return 0;

    return arr[l] + sum(arr, l + 1);

  }

  //测试
  public static void main(String[] args) {
    int[] nums = {1, 2, 3, 4, 5, 6, 7};
    int value = sum(nums);
    System.out.println(value);
  }
}

结果为:28

对上述代码的分析:

Java递归基础与递归的示例分析

以上是“Java递归基础与递归的示例分析”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注创新互联行业资讯频道!


文章名称:Java递归基础与递归的示例分析
网站网址:http://bjjierui.cn/article/ggphjg.html

其他资讯