0

多項式である C++ で最初のクラスを作成していますが、実行時に bad_alloc 例外がスローされました。

P=Q; //(P,Q being polynomials)

bad_alloc がスローされる (そしてプロセスが -1073741819 ステータスで終了することもある) という事実は、メモリがいっぱいであるという事実とはほとんど関係がないと思いますが、それよりも、クラスの構築方法に根本的に問題があるという事実とは関係がないと思います (そして動的メモリを扱うのも初めてです)。どんな助けでも大歓迎です。

class  Polinom
{
    int grad;
    int * coef;
public:
    Polinom(){ coef=new int; coef[0]=0; grad=0;}
    Polinom(int x, int *c);
    Polinom(int x) {coef=new int[x];}
    Polinom(const Polinom &);
    ~Polinom(){ delete[] coef; }
    Polinom operator=(Polinom);
};

Polinom::Polinom(int x, int * c)
{
    int i;
    coef=new int[x];
    for(i=0;i<x;i++)
    {
        coef[i]=c[i];
    }
}

Polinom::Polinom(const Polinom &Q)
{
    int i;
    grad=Q.grad;
    coef=new int[grad];
    for(i=0;i<grad;i++)
    {
        coef[i]=Q.coef[i];
    }
}

Polinom Polinom::operator=(Polinom Q)
{
    int i;
    delete[] coef;
    grad=Q.grad;
    coef=new int[grad];
    for(i=0;i<grad;i++)
        coef[i]=Q.coef[i];

    cout<<"finally";
    return (*this);
}

int main()
{
    int *v,*w;
    int i,n;

    cin>>n;
    v=new int[n];
    for(i=0;i<n;i++){ cin>>v[i]; }
    Polinom P(n,v);
    delete[] v;

    cin>>n;
    w=new int[n];
    for(i=0;i<n;i++){ cin>>w[i]; }
    Polinom Q(n,w);
    delete[] w;

    P=Q;

    return 0;
}
4

1 に答える 1

1

コンストラクターで

Polinom::Polinom(int x, int * c)
{
  int i;
  coef=new int[x];
  for(i=0;i<x;i++)
  {
    coef[i]=c[i];
  }
}

grad の値を x に更新するのを忘れました。= 演算子の Q.grad にゴミが含まれて失敗します。

変更後のコードはこちら

Polinom::Polinom(int x, int * c)
{
  int i;
  grad = x;
  coef=new int[x];
  for(i=0;i<x;i++)
  {
    coef[i]=c[i];
  }
}
于 2015-03-09T18:04:24.077 に答える