`
sunnymoon
  • 浏览: 89609 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

数据结构与算法(JAVA篇)之递归算法(一)

阅读更多
/**
 *
 * @author SunnyMoon
 */


/**
 * 概念介绍:
 * 递归是一种方法(函数)调用自已编程技术。
 * 递归就是程序设计中的数学归纳法。
 * 例如:tri(n)=1            if n=1
 *     tri(n)=n+tri(n-1)    if n>1
 * 可能while循环方法执行的速度比递归方法快,但是为什么采用递归呢。
 * 采用递归,是因为它从概念上简化了问题,而不是因为它提高效率。
 */

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;


public class Recursion {//求三角数字的递归算法:1,3,6,10,15,21, ......

    static int theNumber;

    public static void main(String[] args) throws IOException {
        System.out.print("Enter a number: ");
        theNumber = getInt();
        //使用递归时调用,默认
        int theAnswer = triangle(theNumber);
        //使用非递归时调用
        //int theAnswer=triangle2(theNumber);
        System.out.println("Result: " + theAnswer);
    }

    public static int triangle(int n) {//递归方法,循环调用
        if (n == 1) {
            return 1;
        } else {
            return (n + triangle(n - 1));
        }
    }

    public static int triangle2(int n) {//非递归方法
        int total = 0;
        while (n > 0) {
            total = total + n--;
        }
        return total;
    }

    public static String getString() throws IOException {
        InputStreamReader isr = new InputStreamReader(System.in);
        BufferedReader br = new BufferedReader(isr);
        String s = br.readLine();
        return s;
    }

    public static int getInt() throws IOException {
        String s = getString();
        return Integer.parseInt(s);
    }
}

/**
 * 运行结果:
 * Enter a number: 
 * 3
 * Result: 6
 */

/**
 * 总结:
 * 使用非递归的方式更简洁,更易懂,运行效率更高,为什么还要用递归的算法呢。
 * 递归使规模逐渐降低的方式解决问题,以这种统一的方式解决足够复杂的问题。
 */

 

 


 

 

 

 

分享到:
评论
16 楼 zhangjialu_vip 2013-11-22  
并不是所有的递归都可以用非递归来转换呀
15 楼 sunnymoon 2008-12-12  
lizhaosuper 写道

递归是为了解决一些不能直接利用数学公式计算出来的一些特殊问题,比如汉诺塔问题,你是无法用数学表达式准确推算出第n项的表达式,只能运用递归的方法来解,当然有些可以用递归方法来解的用其他的方法也可以甚至会效率更高,只能说用递归能解决一些你用常规办法不能解决的问题这才是递归的真正用途。个人见解,要是不正确还望指出谢谢!!!!!!!!


很同意你的观点。
递归的真正用意不是在于提高了运行效率,而是提高了解决问题简便性。
用递归的思想解决很复杂的问题时效果就会很明显。good!
14 楼 lizhaosuper 2008-12-12  
递归是为了解决一些不能直接利用数学公式计算出来的一些特殊问题,比如汉诺塔问题,你是无法用数学表达式准确推算出第n项的表达式,只能运用递归的方法来解,当然有些可以用递归方法来解的用其他的方法也可以甚至会效率更高,只能说用递归能解决一些你用常规办法不能解决的问题这才是递归的真正用途。个人见解,要是不正确还望指出谢谢!!!!!!!!
13 楼 sunnymoon 2008-12-12  
Element & lina 写道

sunnymoon 写道

lifethinker 写道
sunnymoon 写道 /** * 总结: * 使用非递归的方式更简洁,更易懂,运行效率更高,为什么还要用递归的算法呢。 * 递归使规模逐渐降低的方式解决问题,以这种统一的方式解决足够复杂的问题。 */ 你的说法不对,大多数情况下,递归要比非递归的效率要高,仅对少数尾递归,它可以很容易的转换为非递归形式的情况下,非递归的效率才比较高。你试着将快速排序转换成非递归的形式(这可不是件容易的事),看看它们的效率的谁高? Hi, 你好。看得出来你是一个高手。 我想说的仅在本例子中的情况,并且试图说明在非递归比递归的效率高的情况下为什么还会使用到递归,另外以此引出一此程序设计的思想(问题规模转化),仅此而已。 你说的很对,我们以后再继续研究更复杂的情况吧。 Best regards, Br, SunnyMoon看来你经常写邮件,递归非递归who效率高这个问题没有context讨论起来有意义吗

请参考博客后继的几篇, 这篇只是初步的介绍。
12 楼 sunnymoon 2008-12-11  
xjlsgcjdtc 写道

首先我要说一下,递归并不是一个广义上的算法,只是一种实现某种算法的手段和方法 其次,把递归和非递归各有利弊,前者耗内存,后者则时间较长,当然在小的程序上采用那种是无所谓的, 但是当程序很大时,就需要权衡使用两者



算法即方法和手段,把方法和手段用在计算机语言里加以理论化系统化就出现了算法。
递归不依赖于任何语言,从这就可以看得出。
递归和非递归是各有得弊说的很对。
有此时候如果把递归改成非递归效率更高,但也不是所有的。
有性趣请看我的另外三篇:http://sunnymoon.iteye.com/category/46944
数据结构与算法(JAVA篇)之递归算法(二)
数据结构与算法(JAVA篇)之递归算法(三)
数据结构与算法(JAVA篇)之递归算法(四)
11 楼 sunnymoon 2008-12-11  
xjlsgcjdtc 写道

首先我要说一下,递归并不是一个广义上的算法,只是一种实现某种算法的手段和方法 其次,把递归和非递归各有利弊,前者耗内存,后者则时间较长,当然在小的程序上采用那种是无所谓的, 但是当程序很大时,就需要权衡使用两者

不好意思,不有及时回你。
我觉得递归和前序遍历说的不是一回事。
递归是一种思想。
前序遍历是一种访问方式。例如:树
10 楼 xjlsgcjdtc 2008-12-11  
首先我要说一下,递归并不是一个广义上的算法,只是一种实现某种算法的手段和方法
其次,把递归和非递归各有利弊,前者耗内存,后者则时间较长,当然在小的程序上采用那种是无所谓的,
但是当程序很大时,就需要权衡使用两者
9 楼 only_java 2008-12-11  
博主觉得我说的有理不?之前是PHP版的,现在发一个JAVA版的
package test;
import java.util.*;
class category{
	String name;
	int id;
	int pid;
	category(String name,int id,int pid){
		this.name=name;
		this.id=id;
		this.pid=pid;
	}
}
public class digui {
  String  res="";
   public String tree(Collection co,int pid){
	     Iterator<category> it=co.iterator();
	     while(it.hasNext()){
	    	  category ct=it.next();
	    	  if(ct.pid==pid){
	    		  int id=ct.id;
	    		   res+=Integer.valueOf(id)+",";
	    		   tree(co,id);
	    	  }
	     }
	     return res;
   }
   public static void main(String[] args){
	   Collection<category> co=new ArrayList<category>();
	   co.add(new category("食物",1,0));
	   co.add(new category("植物",2,0));
	   co.add(new category("水果",3,1));
	   co.add(new category("树",4,2));
	   co.add(new category("苹果",5,3));
	   co.add(new category("松树",6,4));
	   co.add(new category("饮料",7,1)); 
	   co.add(new category("红苹果",8,5));
	   digui dg=new digui();
	   String ress=dg.tree(co, 0);
	   System.out.println(ress);
	  
	   
   }
	
}

8 楼 Element&lina 2008-12-03  
sunnymoon 写道
lifethinker 写道

sunnymoon 写道

/**&nbsp;* 总结:&nbsp;* 使用非递归的方式更简洁,更易懂,运行效率更高,为什么还要用递归的算法呢。&nbsp;* 递归使规模逐渐降低的方式解决问题,以这种统一的方式解决足够复杂的问题。&nbsp;*/
你的说法不对,大多数情况下,递归要比非递归的效率要高,仅对少数尾递归,它可以很容易的转换为非递归形式的情况下,非递归的效率才比较高。你试着将快速排序转换成非递归的形式(这可不是件容易的事),看看它们的效率的谁高?

Hi,

你好。看得出来你是一个高手。
我想说的仅在本例子中的情况,并且试图说明在非递归比递归的效率高的情况下为什么还会使用到递归,另外以此引出一此程序设计的思想(问题规模转化),仅此而已。
你说的很对,我们以后再继续研究更复杂的情况吧。

Best regards,
Br,
SunnyMoon



看来你经常写邮件,递归非递归who效率高这个问题没有context讨论起来有意义吗
7 楼 only_java 2008-12-03  
我觉得递归就像一个前序遍历的过程,
我以PHP代码为例:
$ar=array(0=>array('name'=>'食物','id'=>1,'pid'=>0),
          1=>array('name'=>'植物','id'=>2,'pid'=>0),
          3=>array('name'=>'水果','id'=>3,'pid'=>1),
          4=>array('name'=>'树','id'=>4,'pid'=>2), 
          5=>array('name'=>'苹果','id'=>5,'pid'=>3),
          6=>array('name'=>'松树','id'=>6,'pid'=>4),
          7=>array('name'=>'饮料','id'=>7,'pid'=>1),
             8=>array('name'=>'红苹果','id'=>8,'pid'=>5)     
);
function tree($tree,$pid,&$res=""){
	foreach ($tree as $key=>$items){
		  if($items['pid']==$pid){
		  	         $newid=$items['id'];
                	 $res.=$newid.",";
                	 tree($tree,$newid,$res);
					 
	     	  } 
	}
	return $res;
}
echo tree($ar,0);

结果是:1,3,5,8,7,2,4,6,
我们可以给出一棵树更直观
                    0
            1          2
         3      7    4
         5           6
         8
6 楼 sunnymoon 2008-11-20  
lifethinker 写道

sunnymoon 写道

/**&nbsp;* 总结:&nbsp;* 使用非递归的方式更简洁,更易懂,运行效率更高,为什么还要用递归的算法呢。&nbsp;* 递归使规模逐渐降低的方式解决问题,以这种统一的方式解决足够复杂的问题。&nbsp;*/
你的说法不对,大多数情况下,递归要比非递归的效率要高,仅对少数尾递归,它可以很容易的转换为非递归形式的情况下,非递归的效率才比较高。你试着将快速排序转换成非递归的形式(这可不是件容易的事),看看它们的效率的谁高?

Hi,

你好。看得出来你是一个高手。
我想说的仅在本例子中的情况,并且试图说明在非递归比递归的效率高的情况下为什么还会使用到递归,另外以此引出一此程序设计的思想(问题规模转化),仅此而已。
你说的很对,我们以后再继续研究更复杂的情况吧。

Best regards,
Br,
SunnyMoon
5 楼 jiyanliang 2008-11-20  
<div class='quote_title'>lifethinker 写道</div>
<div class='quote_div'>
<div class='quote_title'>sunnymoon 写道</div>
<div class='quote_div'>
<p><span style='color: #ff0000; font-family: verdana,geneva;'>/**<br/> * 总结:<br/> * 使用非递归的方式更简洁,更易懂,运行效率更高,为什么还要用递归的算法呢。<br/> * 递归使规模逐渐降低的方式解决问题,以这种统一的方式解决足够复杂的问题。<br/> */</span></p>
</div>
<p>你的说法不对,大多数情况下,递归要比非递归的效率要高,仅对少数尾递归,它可以很容易的转换为非递归形式的情况下,非递归的效率才比较高。你试着将快速排序转换成非递归的形式(这可不是件容易的事),看看它们的效率的谁高?</p>
</div>
<p><br/>那要看保存多少现场了。</p>
4 楼 sunnymoon 2008-11-20  
看来我来这里是正确的,这里的人气很旺,而且大家的水平都不差。
我以前用CSDN的Blog,试试看的太度发了一篇,来到这里后感觉喜欢上了这里。以后把家安到这里,在这里建家了。
另外感谢朋友们的热情回复。
3 楼 lifethinker 2008-11-20  
<div class='quote_title'>sunnymoon 写道</div>
<div class='quote_div'>
<p><span style='font-family: verdana,geneva; color: #ff0000;'>/**<br/> * 总结:<br/> * 使用非递归的方式更简洁,更易懂,运行效率更高,为什么还要用递归的算法呢。<br/> * 递归使规模逐渐降低的方式解决问题,以这种统一的方式解决足够复杂的问题。<br/> */</span></p>
</div>
<p>你的说法不对,大多数情况下,递归要比非递归的效率要高,仅对少数尾递归,它可以很容易的转换为非递归形式的情况下,非递归的效率才比较高。你试着将快速排序转换成非递归的形式(这可不是件容易的事),看看它们的效率的谁高?</p>
2 楼 xuming9 2008-11-20  
递归用了很多年了,感觉递归简单易懂
1 楼 dxiao2 2008-11-20  
感觉递归还是很好用的
尤其是多个方法相互递归 能解决些复杂问题

相关推荐

    数据结构与算法(JAVA篇)之递归算法(二)

    ### 数据结构与算法(JAVA篇)之递归算法(二) #### 递归与二分查找 本文将探讨递归算法中的一个重要应用——二分查找,并对比递归与非递归两种实现方式。 ##### 递归的概念介绍 递归是一种算法设计策略,它...

    java数据结构与算法.pdf

    Java作为广泛应用的编程语言,其在实现数据结构和算法时有着丰富的库支持和优秀的可读性。下面将对标题和描述中提到的一些关键知识点进行详细解释。 1. **数据结构**: - **稀疏数组**:当大量数据中大部分为零或...

    数据结构与算法(JAVA语言版)

    数据结构与算法是计算机科学的基础,对于理解和解决复杂问题至关重要。...通过阅读《数据结构与算法(JAVA语言版)》这本书,你将深入理解这些概念,并能熟练运用Java语言实现它们,从而提升你的编程能力。

    数据结构与算法(JAVA篇)之递归算法

    ### 数据结构与算法(JAVA篇)之递归算法 #### 概念介绍 递归算法是一种常见的编程技术,尤其在解决具有重复子问题的问题时非常有效。递归算法的特点是函数自身调用自身来解决问题的不同部分,直到达到基本情况...

    java数据结构递归算法

    在这个"java数据结构递归算法"主题中,我们将深入探讨递归的基本概念、如何在Java中使用递归,以及一个著名的递归应用案例——八皇后问题。 递归是函数或方法调用自身的过程。它基于一个问题的规模缩小至基本情况,...

    数据结构与算法分析(java版内含源代码)

    《数据结构与算法分析》是计算机科学领域的一本经典著作,尤其在Java版本中,它深入探讨了如何在Java编程语言中实现各种数据结构和算法。这本书不仅提供了理论知识,还通过提供源代码实例,帮助读者更好地理解和应用...

    数据结构与算法分析(Java语言描述)习题答案(第三版).docx

    在《数据结构与算法分析(Java语言描述)》(第三版)这本教材中,我们看到涉及了关于数据结构、算法以及程序设计的基础概念。在给出的文档中,部分题目和答案涵盖了递归、数学推理、文件处理以及计算理论等多个方面...

    数据结构与算法分析_java语言描述

    本书的目的是从抽象思维和问题求解的观点提供对数据结构的实用介绍,试图包含有关数据结构、算法分析及其Java实现的所有重要的细节。作者采用了独特的方法将数据结构分成说明和实现两部分,并充分利用了已有的数据...

    数据结构与算法(java版)

    数据结构与算法是计算机科学的基础,对于理解和解决复杂问题至关重要。在Java环境下,这些概念的实现使得程序设计更加高效和优化。以下将详细介绍标题和描述中提到的关键知识点: 1. **栈与队列**: - 栈(Stack)...

    数据结构与算法JAVA版

    本资料包“数据结构与算法JAVA版”聚焦于这个核心主题,包含了用Java实现的各种数据结构和算法。 1. **数据结构**: - **数组**:是最基本的数据结构,提供了固定大小的存储空间,通过索引访问元素。Java中的数组...

    数据结构与算法分析java版

    《数据结构与算法分析Java版》是一本由Robert Lafore撰写的书籍,该书详细介绍了如何利用Java编程语言来实现和操作各种数据结构和算法。全书共分为六个部分,分别涵盖了数据结构的基本概念、数组、简单的排序算法、...

    数据结构与算法 java版

    《Java数据结构与算法.pdf》是一本中文版的教程,它涵盖了数据结构如数组、链表、栈、队列、树、图、哈希表等的基本概念和实现。这些数据结构是解决复杂问题的基础,比如搜索、排序、优化存储和提高查询效率。在Java...

    Java数据结构和算法.pdf

    资源摘要信息是关于Java数据结构和算法的知识点总结,涵盖了数组、栈与队列、链表、递归、哈希表、高级排序、二叉树、红黑树、堆、带权图等数据结构和算法概念。 一、数组 * 数组是相同类型变量的集合,可以使用...

    数据结构与算法java版

    《数据结构与算法Java版》不仅是一本学习Java编程的教材,更是一部深入了解数据结构与算法原理、提升编程技能的宝典。通过系统学习本书内容,读者将能够掌握数据结构与算法的基本概念、设计原则和实现技巧,为后续的...

    C、C++、JAVA数据结构与算法电子书

    数据结构与算法是计算机科学的基础,对于理解和编写高效软件至关重要。C、C++和Java都是广泛使用的编程语言,它们在处理数据结构和算法时各有特点。以下是对这三种语言在数据结构与算法方面的一些关键知识点的详细...

    数据结构与算法java版-不是很高清,不过还算全

    "数据结构与算法java版"这个资源虽然清晰度不高,但内容较为全面,涵盖了数据结构和算法的核心概念。 1. **数据结构**:数据结构是指在计算机中组织和存储数据的方式,它允许我们以高效的方式访问和修改数据。主要...

    数据结构与算法Java语言描述 部分代码实现

    本资源提供了"数据结构与算法Java语言描述 第二版 部分代码实现",这意味着你将能够学习到如何使用Java来实现各种数据结构和算法。 1. **数组**:数组是最基本的数据结构,它允许存储固定大小的同类型元素集合。在...

    数据结构与算法分析_Java语言描述(第2版) 源代码

    《数据结构与算法分析_Java语言描述(第2版) 源代码》是一本深入探讨数据结构和算法的书籍,其源代码是学习和理解书中理论的重要实践资源。这本书籍主要面向计算机科学专业的学生以及对算法有深入研究需求的开发者。...

Global site tag (gtag.js) - Google Analytics