我不知道如何纠正我的尾递归(最初的常规递归)

时间:2016-12-01 18:27:50

标签: c recursion tail-recursion

我被分配了funct()并被告知将其转换为尾递归,所以我做了funct2()。我使用了另一个堆栈溢出thread来开始它有点工作,但它始终是一个值。

认为问题是由于 y 值最初为0,并且当转到 else 部分时,减去来自 0 ,而不是相当于初始 x 的值。但我不确定。

#include <iostream>
#include <stdio.h>
using namespace std;
int funct(int x);
int funct2(int x, int y);

int main() {

    int x = 24;

    printf("%d %d", funct(x), funct2(x, 0));


}

int funct(int x) {

    if (x <= 0){
        return 0;
    }
    else if (x & 0x01){
        return x + funct(x-1);
    }
    else {
        return x - funct(x-1);
    }

}

int funct2(int x, int y) {

    if (x < 0){
        return 0;
    }
    else if (x == 0){
        return y;
    }
    else if (x & 0x01){
        return funct2(x-1, y+x);
    }
    else {
        return funct2(x-1, y-(x-1));
    }

}

感谢任何帮助。谢谢你们!

1 个答案:

答案 0 :(得分:1)

看看this great explanation。由于递归步骤不是关联的,因此只能使用两个参数来实现尾递归。考虑通过三个:

    int tailrec(int x, int k, int acc)
    {
        if (x < 0) {
            return acc;
        }
        if (k & 0x01) {
            return tailrec(x - 1, k + 1, k + acc);
        } else {
            return tailrec(x - 1, k + 1, k - acc);
        }
    }