动态分配数组中的运行时错误,用于删除 C++ 中的元素



我用C++编写了一个程序来删除动态分配的数组中的元素。我可以看到带有已删除元素的数组,但在那之后,它会产生一些我无法理解的错误。我已将图像包含在错误中,因为我无法复制错误消息。我正在使用:

Debian 9,32 位

编译器叮当声。

IDE代码::块。

代码:

#include<iostream>
#include<cstdlib>
using namespace std;
int main()
{
    int *ar,arsize,lp1,lp2,lp3,lp4,ele,pos;
    ar=nullptr;
    cout<<"enter the size of array to be created:- "; cin>>arsize;
    ar=new int[arsize];
    if(!ar)
    {
        cout<<"Aborting";
        exit(1);
    }
    else
    {
    cout<<"enter the elements for array:- ";
    for(lp1=0;lp1<arsize;lp1++)
    {
        cin>>ar[lp1];
    }
    cout<<"Enter element to be deleted:- "; cin>>ele;
    for(lp2=0;lp2<arsize;lp2++)
    {
        if(ar[lp2]==ele)
        {
            ar[lp2]=0;
            pos=lp2;
            break;
        }
    }
    for(lp3=pos;lp3<arsize;lp3++)
    {
        ar[lp3]=ar[lp3+1];
    }
    ar[arsize]=0;
    cout<<"new array is:-"<<endl;
    for(lp4=0;lp4<arsize-1;lp4++)
    {
        cout<<"t"<<ar[lp4]<<endl;
    }
    delete[]ar;
    return 0;
    }
}

此代码具有未定义的行为:

 ar[lp3]=ar[lp3+1];

由于lp3指向最后一个元素,因此ar[lp3+1];超出范围。

也:

ar[arsize]=0;

越界写入。最大有效索引是arsize-1,因为索引从零开始。最后一行会损坏您的堆。

您正在尝试访问不存在的ar[arsize]

请记住,C++数组的索引为 0。

所以试试ar[arsize-1]

最新更新