c++ - 使用全局声明的 vector 时 C++ 中的双重错误/损坏

标签 c++ stl global-variables stdvector double-free

对于这段代码,

#include<bits/stdc++.h>
#include<iostream>
#include<vector>

using namespace std;

vector<long long int> v1,v2;

    int main(int argc, char const *argv[]){
        long long int t, n, i, x, day_count;
        scanf("%llu", &t);
        while(t--){
            scanf("%llu", &n);
            for(i=0; i<n; i++){
                scanf("%llu", &x);
                v1.push_back(x);
                v2.push_back(0);
            }
            day_count = SpreadTheWord(n);
            printf("%llu\n", day_count);    
            v1.clear();
            v2.clear();
        }  
        return 0;
    }

我得到了我想要的输出,但是在 main 执行“return 0”之后,我得到了这个错误

*** Error in `./a.out': double free or corruption (!prev): 0x0000000001d62e20 ***

我使用另一个代码得到了答案,但我想了解为什么此代码会出现此错误。

我不认为 SpreadTheWord() 有什么问题,但以防万一你想看看 SpreadTheWord() 做了什么

long long int SpreadTheWord(long long int n){
    long long int dc = 0;
    long long int i = 0, j, m;
    j = i + 1;
    long long int k = v1[i];
    v2[i] = 2;
    while(true){
        if(v2[n-1] == 2){ //condition 1
            return dc;
        }
        if(k!=0 && v2[i] == 2){ //condition 2
            v2[j] = 1;
            k--;
            j++;
        }
        else if(k==0){ //condition 3
            i++;
            if(v2[i] == 2)  //condition 3.1
                k = v1[i];
            else{               //condition 3.2
                m= 0;
                while(v2[m] != 0){
                    v2[m] = 2;
                    m++;
                }
                i = 0;
                dc++;
                k = v1[i];
            }
        }
    }
    return dc;
}

谢谢!

编辑:对不起,我忘了附上输入

3
10
1 1 1 1 1 1 1 1 1 1
10
2 2 2 2 2 2 2 2 2 2
10
3 3 3 3 3 3 3 3 3 3 

问题出在这里:https://www.codechef.com/SNCKQL19/problems/SPREAD2

最佳答案

            while(v2[m] != 0){
                v2[m] = 2;
                m++;
            }
    if(k!=0 && v2[i] == 2){ //condition 2
        v2[j] = 1;
        k--;
        j++;
    }

证明 v2[j]v2[m] 总是在 v2 的范围内是非常重要的。

一般来说,SpreadTheWord 是一堆意大利面条逻辑,可能正在破坏堆。


[x] 替换为 .at(x) 以获得异常而不是内存损坏。

声明变量尽可能接近它们的初始化,并尽快让它们脱离范围,以减少变量停留的长度并减少“状态”程序的数量。

给变量起一个合理的名字。

处理以下可能性:

        for(i=0; i<n; i++){
            scanf("%llu", &x);
            v1.push_back(x);
            v2.push_back(0);
        }

n 在这里为零。

您的代码做了足够多的指针和索引运算,如果它没有通过在 vector 上越界写入来破坏堆,我会感到惊讶。

关于c++ - 使用全局声明的 vector 时 C++ 中的双重错误/损坏,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52931954/

相关文章:

c++ - 如何在linux数据类型中定义#define S64_MIN?

c++ - 当 SIGSEGV 出现在 Windows 应用程序中时,我可以获得堆栈跟踪吗?

c++ - 为什么与 "end()"迭代器进行比较是合法的?

c++ - 在所有节点作为结构 C++ 的排序列表中进行二进制搜索

c++ - 带有 O1、O2 或 O3 的 gcc 4.7.3 创建错误代码

c++ - 在调用中使用结构从 vb.net 调用

c++ - vector::erase with pointer 成员

python - Tkinter 按钮命令不运行

c - 如何声明一个只存在于一个函数中的全局变量?

javascript - 我怎样才能让这个javascript函数不使用全局变量?