以下是全部代码,编译链接无误,但生成的exe文件只打印两句话就没了,debug也没办法
#ifndef DETER
#define DETER
#include <iostream.h>
#include <process.h>
class Deter
{
public:
Deter(int );
int getelemt(int line,int queue)
{ if(line<size&&queue<size)
return arry[line][queue];
else return -1;
}
void setelemt(int line,int queue,int num)
{ if(line<size&&queue<size)
arry[line][queue]=num;
}
int sizet(){return size;}
Deter* getconf(int line )
{
if(line<size)
return conf[line];
else return NULL;
}
int value();
void printelemt();
void Deter_initial();
private:
void conf_initial(); //初始化所有余子式
int **arry; //行列式数组
Deter** conf; //余子式
int size; //行列式阶数
};
Deter::Deter(int isize)
{
size=isize;
arry=new int* [size];
if (arry)
for (int i=0;i<size;i++)
{arry[i]=new int [size];
if(!arry[i])
cerr<<"No enough memory avilable!\n";
exit(1);
}
else
{ exit(1);cerr<<"No enough memory avilable!\n";}
conf=new Deter* [size]; //n阶行列式在第一列展开有n个余子式
if (conf)
for (int i=0;i<size;i++)
{
conf[i]=new Deter(size-1);
if (!conf[i])
{ exit(1);cerr<<"No enough memory avilable!\n";}
}
}
void Deter::Deter_initial()
{
for (int l=0;l<size;l++)
{
for (int q=0;q<size;q++)
{ int c=0;
cin>>c; //外部输入数据
setelemt(l,q,c);
}
}
cout<<"初始化完毕!"<<endl;
conf_initial();
}
void Deter::conf_initial() //取行列式第一列展开的所有余子式
{
for (int k=0;k<size;k++) //初始每个余子式
{
for (int l=0;l<size-1;l++) //行控制循环
for (int q=0;q<size-1;q++) //列控制循环
{
int position=l;
if (position==k) position++; //copy元素
(conf[k])->setelemt(l,q,this->getelemt(position,q+1));
}
}
}
int Deter::value() //求值
{
if(size==1)
return this->getelemt(0,0); //递归首项
else
{ int dvalue=0;
for (int i=0;i<size+1;i++)
{
if(i%2==0)
dvalue+=getelemt(i,0)*(getconf(i)->value()); //递归求值
else
dvalue-=getelemt(i,0)*(getconf(i)->value());
}
return dvalue;
}
}
void Deter::printelemt() //打印行列式
{
for(int l=0;l<size;l++)
{ for (int q=0;q<size;q++)
{
cout<<getelemt(l,q)<<" ";
}
cout<<endl;
}
}
#endif
/////////////////主程序
#include "determinant.h"
int main()
{ int sizet;
cout<<"----------------行列式计算工具-----------------"<<endl;
cout<<"行列式阶数: ";cin>>sizet;
Deter det(sizet);
det.Deter_initial();
det.printelemt();
cout<<"计算结果:"<<det.value()<<endl;
return 0;
}
不知道是算法错误还是其他的甚么错误
哪位路过的给看看,感激不尽
[求助]行列式求值程序 错误在哪?