1

我在 XP 虚拟机中的 MingW 编译器上运行 CodeBlocks。我写了一些简单的代码,可在cl1p访问,它回答了CodeChef的算法问题(好吧,它只回答了部分问题,因为我还没有包含多个测试用例的循环。

但是,我的问题是,在调试模式下运行它时,它会为输入提供正确的输出 5:

3
1
2 1
1 2 3

但是,当我构建并运行它时,它给出了荒谬的巨大输出 131078,这对我来说似乎是垃圾。我不明白这是怎么回事,但我猜这与动态内存分配有关。这里有什么问题,我该如何解决?我什至通过BotSkool的在线编译器运行它,它运行良好。为测试用例添加循环后,代码甚至在 CodeChef 上也能正常工作!

#include <iostream>

using namespace std;

int main()
{
    // Take In number of rows
    int numofrows;
    cin >> numofrows;

    // Input Only item in first row
    int * prevrow;
    prevrow = new int[1];
    cin >> prevrow[0];

    // For every other row
    for (int currownum = 1; currownum < numofrows; currownum++)
    {
        // Declare an array for that row's max values
        int * currow;
        currow = new int[currownum+1];

        int curnum;
        cin >> curnum;

        // If its the first element, max is prevmax + current input
        currow[0] = prevrow[0] + curnum;

        // for every element
        int i = 1;
        for (; i <= currownum; i++)
        {
            cin >> curnum;

            // if its not the first element, check whether prevmax or prev-1max is greater. Add to current input
            int max = (prevrow[i] > prevrow[i-1]) ? prevrow[i] : prevrow[i-1];

            // save as currmax.
            currow[i] = max + curnum;
        }

        // save entire array in prev
        prevrow = new int[i+1];
        prevrow = currow;
    }

    // get highest element of array
    int ans = 0;
    for (int j=0; j<numofrows; j++)
    {
        if (prevrow[j] > ans)
        {
            ans = prevrow[j];
        }
    }

    cout << ans;
}
4

3 回答 3

2

在 Linux 机器上通过 Valgrind 运行代码,你会惊讶于你的代码在多少地方泄漏了内存。如果您正在走管理内存的艰难道路,请做好并在分配更多内存之前“删除”所有新分配的内存。另一方面,如果您更喜欢简单的道路,请使用 std::vector 并忘记内存管理。

于 2010-01-01T22:17:11.713 回答
1

一方面,这是:

    //save entire array in prev
    prevrow = new int [i+1];
    prevrow = currow;

复制指针,而不是整个数组。

于 2010-01-01T22:15:22.320 回答
1

在你的循环中,你有这条线

int max = (prevrow[i]>prevrow[i-1])?prevrow[i]:prevrow[i-1];

在主循环的第一次迭代时currownum == 1,将进入包含该行的循环,i初始化为1。但是在第一次迭代中,prevrow只有一个元素,这一行尝试访问prevrow[1]. 在调试构建中,内存只是简单地初始化为零,但在正常构建中,您会得到一些恰好在内存中的垃圾值,从而导致您看到的结果。

几乎总是,当您在正常构建中获得垃圾值,但在调试构建中一切正常时,您正在访问一些未初始化的内存。

此外,您的程序正在疯狂地泄漏内存。例如,您不需要将new循环内的任何结果分配给,prevrow因为之后您立即更改prevrow为指向另一个分配的内存块。此外,您应该调用delete您不再使用的任何内存。

于 2010-01-01T22:25:43.673 回答