`
yangyiqian
  • 浏览: 117870 次
  • 来自: ...
社区版块
存档分类
最新评论

迭代与递归

    博客分类:
  • JAVA
 
阅读更多
public class Test {

public int f1(int n) {
int result = 1;
while (n > 1) {
result *= n;
--n;
}

return result;
}

public static int f2(int n) {
if (n == 1)
return 1;

else
return n * f2(n - 1);

}

public static void main(String[] args) {
Test t = new Test();
System.out.println(new Date());
t.f1(999999999);
System.out.println(new Date());


}

}



以上代码充分说明,迭代在性能上以及稳定性上要好于递归调用
分享到:
评论

相关推荐

    迭代与递归的区别

    在计算机编程中,迭代与递归是两种常用的解决重复性问题的方法。它们各自有不同的特点和适用场景。理解它们之间的区别,对于编写高效和优雅的代码至关重要。 迭代是一种方法,它通过重复执行一组指令来逐步逼近最终...

    DSAinC++3-遍历迭代与递归1

    递归与迭代的关系: - 递归是迭代的一种特殊情况,当递归函数的每次调用都在减少问题规模,且最终会达到基本情况时,这种递归可以转换为迭代形式。 - 相反,迭代通常更高效,因为它避免了函数调用的开销,但在某些...

    迭代与递归算法

    在编程和算法设计中,迭代和递归是两种常见的解决问题的方法。它们在处理循环和层次结构问题时尤其重要,尤其在C语言和其他编程语言中。本文将深入探讨这两种方法,以及它们在实际应用中的差异。 **迭代算法**是...

    迭代和递归1.2.pptx

    公司要求分享迭代和递归函数,在周末的时间整理了一个简单的PPT,在这里也分享给大家,互相学些,相互总结。

    DNS迭代查询和递归查询的区别.docx

    "DNS 迭代查询和递归查询的区别" DNS(Domain Name System)是 Internet 中的一个基础设施,提供域名到 IP 地址的映射服务。在 DNS 解析过程中,查询类型是一个关键概念,有两种主要的查询类型:迭代查询和递归查询...

    牛顿迭代算法与递归算法的概念和区别

    在算法的世界里,牛顿迭代算法和递归算法各有千秋,它们是解决问题的两种重要思路。理解它们的概念和区别对于选择正确的工具来解决特定问题至关重要。 牛顿迭代算法,也称为牛顿-拉弗森方法,是一种迭代逼近技术,...

    oracle递归、迭代

    ### Oracle中的递归查询详解 #### 一、引言 在数据库管理中,处理具有层次结构的数据是一项常见的任务。例如,在组织结构、产品分类或文件系统等场景中,经常需要查询这种类型的层级数据。Oracle数据库提供了强大...

    PHP迭代与递归实现无限级分类

    本文将探讨两种实现无限级分类的方法:循环迭代和递归。 1. 循环迭代实现 这种方法是通过遍历数据数组,根据每个元素的“father”属性来构建父子关系。关键在于利用数组引用,将子元素添加到其父元素的“son”属性...

    C语言实现 求二项式各项系数(迭代,递归)

    本文将围绕“C语言实现求二项式各项系数(迭代,递归法)”这一主题,深入探讨如何利用C语言通过迭代和递归两种方法来计算二项式系数,这不仅体现了C语言的强大功能,也展示了编程中不同算法的运用与对比。...

    C++:斐波那契数列(迭代和递归)

    总结来说,C++提供了多种方式来实现斐波那契数列,包括迭代和递归,以及递归的优化形式——记忆化。在实际应用中,我们需要根据问题规模和性能需求选择合适的方法。对于小规模的计算,递归可能更为直观;而大型计算...

    c语言-阶乘算法(迭代和递归).docx

    C语言-阶乘算法(迭代和递归) C语言-阶乘算法是计算阶乘的经典算法,包括迭代算法和递归算法两种实现方式。阶乘是数学中的一种运算符号,表示一个数字的所有正整数因子的乘积,如n! = n * (n-1) * (n-2) * (n-3) * ....

    递归与迭代算法及其在JAVA语言中的应用.pdf

    递归与迭代是算法设计中两种常见的解决问题的方法,它们在Java语言中的应用广泛且具有深远的意义。递归算法通过方法内部调用自身来解决问题,它适合于可以分解为相似子问题的问题;而迭代算法则通过循环结构,不断...

    使用迭代和递归两种方法反转链表.docx

    ### 使用迭代和递归两种方法反转链表 在计算机科学中,链表是一种常见的数据结构,广泛应用于多种算法和数据处理场景中。反转链表是一个经典的面试题目,它不仅能够考察求职者的编程基础,还能检验其对递归的理解...

    python中的函数递归和迭代原理解析

    在Python编程中,函数递归和迭代是两种不同的解决问题的方法,它们各自具有独特的特性和应用场景。本文将深入解析这两种概念,帮助你更好地理解和运用它们。 首先,让我们详细探讨函数递归。递归是一种程序设计技术...

    BinarySearchUdemy:迭代和递归二进制搜索实现

    下面,我们将详细阐述二进制搜索的基本原理、迭代与递归实现方法,以及C#中的具体应用。 **二进制搜索的基本原理** 二进制搜索的核心思想是分治法。它首先将目标值与数组的中间元素进行比较,根据比较结果决定是在...

    java查找链表的长度(迭代和递归)

    java查找链表的长度(迭代和递归) 给定一个单向链表,任务是找到链表的长度。 以下是求链表长度的方法: 将 count 初始化为 0。 初始化一个节点指针 curr = head。 在 curr 不为 NULL 时执行以下操作 curr = curr ...

    c查找链表的长度(迭代和递归)

    c//查找链表的长度(迭代和递归) 给定一个单向链表,任务是找到链表的长度。 以下是求链表长度的方法: 将 count 初始化为 0。 初始化一个节点指针 curr = head。 在 curr 不为 NULL 时执行以下操作 curr = curr -...

    python 查找链表的长度(迭代和递归)

    python//查找链表的长度(迭代和递归) 给定一个单向链表,任务是找到链表的长度。 以下是求链表长度的方法: 将 count 初始化为 0。 初始化一个节点指针 curr = head。 在 curr 不为 NULL 时执行以下操作 curr = ...

Global site tag (gtag.js) - Google Analytics