向量超出范围,但是为什么呢?

时间:2019-11-19 01:04:46

标签: c++ arrays matrix multidimensional-array vector

它说我的向量超出ArrayD的范围。但是我不明白为什么。其他一切正常。 Is表示向量在两次deez之后超出范围。因此,它不会完全上升。

使用命名空间标准;

void hello();

void Infile();

x,y,z的双倍;

双P,B;

int E = 0;

双V [16];

双C [16];

双D [16];

int m,n;

int main()

{

Infile();
return 0;

}

void Infile()

{

ifstream fileA("P_matrix.txt");
ifstream fileB("b_matrix.txt");
ifstream fileC("d_matrix.txt");
vector<double>ArrayP;
vector<double>ArrayB;
vector<double>ArrayD;


cout << "P Matrix Values \n";
while (fileA.good())
{
    fileA >> P;
    ArrayP.push_back(P);
}
for (int i = 0; i<ArrayP.size(); i++)
{
    cout << ArrayP[i] << ",";
}
system("pause");



cout << "B Matrix Values \n";
while (fileB.good())
{
    fileB >> B;
    ArrayB.push_back(B);
}
for (int j = 0; j < 16; j++)
{
    cout << ArrayB[j] << ",";
}
system("pause");
while (fileC.good())
{

    fileC >> D;
    ArrayD.push_back(D);


}
for (int k = 0; k <16; k++)
{
    cout << ArrayD[k] << ",";

}

system("pause");


for (int m = 0; m < 16; m++)
{
    V[m] = ArrayP[m] * ArrayB[m];
    cout << V[m] << ",";
}
system("pause");

for (int n = 0; n < 16; n++)
{
    C[n] = V[n] * ArrayD[n];
    cout << C[n] << ",";
}

//outfile.close();
system("pause");

double deez;
for (int d = 0; d < 16; d++) //acscending
{
    for (int q = 0; q < 16; q++)
    {
        if (ArrayD[q] < ArrayD[q - 1])
        {
            deez = ArrayD[q];
            ArrayD[q] = ArrayD[q - 1];
            ArrayD[q - 1] = deez;
        }
    }
}
for (int q = 0; q < 16; q++)
    cout << C[q] << ",";
system("pause");



double nutz;
for (int d = 0; d < 16; d++) //descending
{
    for (int q = 0; q < 16; q++)
    {
        if (V[q] < V[q + 1])
        {
            nutz = V[q];
            V[q] = V[q + 1];
            V[q + 1] = nutz;
        }
    }
}
for (int q = 0; q < 16; q++)
    cout << V[q] << ",";
system("pause");
return;

}


1 个答案:

答案 0 :(得分:1)

在这里,q从零开始,因此您正在尝试访问索引[-1]。

dict = {}

values= [1,1,1,1,1,1,1,1,1,1,..,1]

dict={'x':[1,1,1,1,1,1,1,1,1,1,..,1]}

遍历ArrayP时,您可以正确执行以下操作:

ArrayD[q - 1]

但是对于ArrayB和ArrayC,您似乎假定这些数组中只有16个元素(您确定 ?)。我看不到任何证据表明数组仅限于在代码中始终包含16个元素,因此这也可能是问题。

后来,您似乎还假设所有这些数组都有16个元素?

    for (int i = 0; i<ArrayP.size(); i++)

明显的地方可能会导致超出范围的错误。