zoukankan      html  css  js  c++  java
  • 尾部调用

    在阮一峰大侠的ECMAScript 6 入门

    了解到“尾递归”概念,一旦使用递归,就最好使用尾递归,再也不用担心"栈溢出"(stack overflow)。

    public class BeanInfoDemo {
        public static void main(String[] args) {
            Fibonacci(50);
        }
    
        private static void Fibonacci(int n) {
            long t1 = System.currentTimeMillis();
            System.out.println("传统:" + FibonacciC(n));
            long t2 = System.currentTimeMillis();
            System.out.println("传统耗时:" + (t2 - t1));
            System.out.println("尾部:" + FibonacciNew(n, 1, 1));
            long t3 = System.currentTimeMillis();
            System.out.println("尾部耗时:" + (t3 - t2));
        }
    
        public static long FibonacciC(long n) {
            if (n <= 2) {
                return 1;
            }
            return FibonacciC(n - 1) + FibonacciC(n - 2);
        }
    
        public static long FibonacciNew(long n, long ac1, long ac2) {
            if (n <= 2) {
                return ac2;
            }
            return FibonacciNew(n - 1, ac2, ac1 + ac2);
        }
    
    }

    结果为:

    传统:12586269025
    传统耗时:30040
    尾部:12586269025
    尾部耗时:0

     参考:http://www.ruanyifeng.com/blog/2015/04/tail-call.html

  • 相关阅读:
    [IOI2013]Dreaming
    Lost Cows
    Mobile Service
    [POI2005]Bank notes
    [CTSC2007]动物园zoo
    [CF1093F]Vasya and Array
    [雅礼集训 2017 Day1]市场
    [APIO2014]序列分割
    [CEOI2004]锯木厂选址
    [APIO2010]特别行动队
  • 原文地址:https://www.cnblogs.com/g120/p/12208730.html
Copyright © 2011-2022 走看看