c++ - 递归堆栈溢出 C++

标签 c++ visual-c++ recursion stack-overflow

我是 C++ 的新手,但认为解决一些项目欧拉问题会让我熟悉这门语言。

尝试时 Project Euler Problem 14: Longest Collatz sequence

我无法让我的 C++ 解决方案正常工作,但我的 python 解决方案没有问题...

import time 
start = time.time()
memo = {1:1,2:2}
longest_chain, longest_starting_key = 2, 2

def rec(a):
    global longest_chain, longest_starting_key

    if a in memo.keys():
        return memo[a]    
    if a % 2 == 0:
        memo[a] = rec(a // 2) + 1
    else:
        memo[a] = rec(3 * a + 1) + 1
    if memo[a] > longest_chain:
        longest_chain = memo[a]
        longest_starting_key = a
    return memo[a]    

for i in range(1000000,3,-1): rec(i)

print("starting key", longest_starting_key , ": has length", longest_chain)
print((time.time() - start), "seconds")

得到了

starting key 837799 has length 525
1.399820327758789 seconds

我的 C++ 尝试...(我认为是等价的...)

#include <iostream>
#include <unordered_map>
std::unordered_map<int, int> mem = { {1,1},{2,2} };
int longest_chain{ 2 }, best_starting_num{ 2 };

bool is_in(const int& i){
    auto search = mem.find(i);
    if(search == mem.end())
        return false;
    else
        return true;
}

int f(int n){
    if(is_in(n))
        return mem[n];
    if(n % 2)
        mem[n] = f(3 * n + 1) + 1;
    else
        mem[n] = f(n / 2) + 1;
    if(mem[n] > longest_chain)
        longest_chain = mem[n];
    return mem[n];
}

int main(){
    for(int i = 3; i < 1000000; i++){
        f(i);
    }
    std::cout << longest_chain << std::endl;
}

在 Debug模式下在 Visual Studio 中运行时出现以下错误

Unhandled exception at 0x00007FF75A64EB70 in
0014_longest)collatz_sequence_cpp.exe: 0xC00000FD: Stack overflow
(parameters: 0x0000000000000001, 0x000000DC81493FE0).

有人告诉我应该使用指针在堆上分配,但使用指针的经验非常有限...

我不明白的另一件事是......当我在主体循环中使用 100'000 而不是 1'000'000 运行它时,它可以工作但速度非常慢。

最佳答案

提示:Collat​​z 序列提供(数学上)的 n 范围的不变量是什么,您的 Python 代码满足但您的 C++ 代码不满足?提示中的提示:在实际发生堆栈溢出之前,n 的最后几个值是什么?

关于c++ - 递归堆栈溢出 C++,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39457496/

相关文章:

c++ - 如何在 Restinio 中使用 POST 处理程序?

c - Microsoft C/C++ 链接器优化未能丢弃未使用的代码/数据

c - 调用 CreateWindowEx 函数时出现访问冲突错误

arrays - 找出连续元素的最大可能差异之和

c++ - 有效的 c++ 项目 3 示例

c++ - 链接 jsoncpp (libjson)

c++ - 新的定义

c++ - 通过接近 MAX_PATH 长度的 Windows 网络访问文件

c# - c#中递归的返回类型

python - 如何在 Python 中让我的递归函数返回 0