常用的算法-递归

常用的算法-递归

        最近开始复习数据结构和算法的相关知识,以前学习数据结构的时候使用C语言实现其中的数据存储结构。已经学习Java有一年多了,总是忙于写代码,学习新知识,思考总是一瞬间的事,然而这样的境遇总是让我在学习Java软件开发的过程中遇到很多问题,为此牺牲了很多时间。

      突然决定启用51Blog来记录每一次尝试,探索,错误的历经。

      递归算法的核心在于:

     方法能够通过自身的调用得到执行,并且总会得到调用结束的出口。

     递归(recursion):神奇的算法

      递归编程的注意事项:
      递归代码会精彩而且会很短,但却能够完成很复杂的工作;
      大部分代码是用来对负责底层工作的递归方法进行支持。
   

    递归和迭代的区别:

    迭代:一种用循环来描述需要的重复进行的操作的编程方法。
    递归:一种通过调用某个方法来描述需要重复进行的操作的编程方法,该方法的一个基本特  征是:它可以调用自身


  1. iteration algorithm:  
  2.         public static void writeStar(int n)  
  3.         {  
  4.             for(int i=1;i<n;i++)  
  5.             {  
  6.                 System.out.print(” * “);  
  7.             }  
  8.         System.out.println();  
  9.         }  
  10.     recursion algorithm:  
  11.         public static void writeStar(int n)  
  12.         {  
  13.             if(n==0)  
  14.             {  
  15.                 //base case  
  16.                 System.out.println();  
  17.             }  
  18.             else 
  19.             {  
  20.                 //recursion case  
  21.                 System.out.print(” * “);  
  22.                 writeStar(n-1);  
  23.             }  
  24.         } 


 递归结构:
  基本情况(base case) 递归情况(recursion case)
  基本情况:
    一种简单到不需要递归调用就可以直接解决的情况
  递归情况:
   一种需要把整个问题转化成为一个相同种类,比较简单的,而且可以通过递归调用
  来解决问题的情况
  
 函数调用用的是:栈内存
 主函数的运行用的是:堆内存

 


  1. 整数的幂运算:  
  2.         public static int pow(int x,int y)  
  3.         {  
  4.             if(y==0)  
  5.             {  
  6.                 //base case  
  7.                 return 1;  
  8.             }  
  9.             else 
  10.             {  
  11.                 //recursion case  
  12.                 return x*pow(x,y-1);  
  13.             }  
  14.         }  
  15.         递归解决方法过程:  
  16.         pow(3,5)  =  3*pow(3,4)  
  17.         |   pow(3,4)  =  3*pow(3,3)  
  18.         |   |   pow(3,3)  =  3*pow(3,2)  
  19.         |   |   |   pow(3,2)  =  3*pow(3,1)  
  20.         |   |   |   |   pow(3,1)  =  3*pow(3,0)  
  21.         |   |   |   |   |   pow(3,0)  =  1 
  22.         |   |   |   |   pow(3,1)  =  3*1  =  3 
  23.         |   |   |   pow(3,2)  =  3*3  =  9 
  24.         |   |   pow(3,3)  =  3*9  =  27 
  25.         |   pow(3,4)  =  3*27  =  81 
  26.         pow(3,5)  =  3*81  =  243 

当然递归对于问题的理解和提炼要求是比较高的。

我们使用递归解决的问题:

1.在数据结构中的非线性存储结构中的树,二叉树的前序遍历,中序遍历,后序遍历等问题的解决中就使用了递归算法,这样使解决问题的编码很方便。

2.遍历指定目录下的所有文件

3.二分法排序等等

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/110426.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • HTML5新增及移除的元素

    HTML经过10多年的发展,其元素经历了废弃与不断重新定义的过程。为了更好的处理现在的互联网应用,HTML5新增了图形绘制、多媒体播放、页面结构、应用程序存储、网络工作等新元素。http://hove

    2021年12月27日
  • npm run build: rimraf: command not found

    npm run build: rimraf: command not found当出现以下构建失败的情况时:npmrunbuild>new-proj@0.0.1prebuil>rimrafdistsh:rimraf:commandnotfound可以先执行npminstallrimraf再执行npminstall再次构建npmrunbuild

    2022年10月24日
  • Springmvc工作原理详解

    Springmvc工作原理详解关于三层架构和MVC我们的开发架构一般都是基于两种形式,一种是C/S架构,也就是客户端/服务器,另一种是B/S架构,也就是浏览器服务器。在JavaEE开发中,几乎全都是基于B/S架构的开发。那么在B/S架构中,系统标准的三层架构包括:表现层、业务层、持久层。三层架构在我们的实际开发中使用的非常多,所以我们课程中的案例也都是基于三层架构设计的。三层架构中,每一层各司其…

  • C++和Java中STL库入门[通俗易懂]

    C++和Java中STL库入门[通俗易懂]C++和Java中STL库入门STL简介为什么使用STLSTL基本概念STL使用前的初始化C++里STL基本容器详解STL简介STL简称标准模版库,被容纳在C++标准程序库,包含了许多基本数据结构和基本算法,使程序员写起来得心应手。为什么使用STL在学习数据结构的时候,在程序中会使用到堆、栈、队列、链表等一些基本的算法,而学习数据结构的时候,这些基本算法写起来十分繁琐,如果不想写这些,那么就可以考虑一下STL了。但是不要太过于依赖STL!STL基本概念要使用STL,需要理解以下几个基本概念:

  • Android Hook技术实践

    Android Hook技术实践一、hook简介hook俗称钩子,主要作用是替换系统内存中的对象,在上层调用此对象的方法的时候可以修改传入参数或者返回值,达到欺骗上层的目的,就像小红帽故事里的大灰狼,通过扮演小红帽的外婆的角色来达到欺骗小红帽的目的。其实hook就是一种中间人劫持的思想,如图所示:在安卓中实现hook主要通过两种方式:1.反射技术和代理实现,当然代理不管是动态还是静态的都是可以实现的,但是只能ho

  • java当前时间的时间戳_java获取当前时间(时间戳)的方法

    java当前时间的时间戳_java获取当前时间(时间戳)的方法获取当前时间戳(毫秒级)//方法一System.currentTimeMillis();//方法二Calendar.getInstance().getTimeInMillis();//方法三newDate().getTime();获取当前时间SimpleDateFormatdf=newSimpleDateFormat(“yyyy-MM-ddHH:mm:ss”);//设置日期格式S…

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号