找回密码
 注册
搜索
热搜: 回贴
  • 前程无忧官网首页 有什么好的平台可以
  • 最新的销售平台 互联网营销的平台有哪
  • 制作网页的基本流程 网页制作和网页设
  • 【帝国CMS】输出带序号的列表(数字排
  • 网站建设公司 三一,中联,极东泵车的
  • 织梦 建站 织梦网站模版后台怎么更改
  • 云服务官网 哪些网站有免费的简历模板
  • 如何建网站要什么条件 建网站要用什么
  • 吉林市移动公司电话 吉林省退休人员网
  • 设计类毕业论文 网站设计与实现毕业论
查看: 362|回复: 2

[求助]行列式求值程序 错误在哪?

[复制链接]
发表于 2009-11-5 00:39:17 | 显示全部楼层 |阅读模式 IP:江苏扬州
以下是全部代码,编译链接无误,但生成的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;
}
不知道是算法错误还是其他的甚么错误
哪位路过的给看看,感激不尽
发表于 2009-11-5 00:39:18 | 显示全部楼层 IP:江苏扬州
你跟踪不出来么
这样的问题
一般很少有人有时间看啊
回复

使用道具 举报

发表于 2009-11-5 00:39:19 | 显示全部楼层 IP:江苏扬州
也知道,我自己逛论坛看到这样长的代码都懒得看
实在是没办法了
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

QQ|小黑屋|最新主题|手机版|微赢网络技术论坛 ( 苏ICP备08020429号 )

GMT+8, 2024-10-1 07:34 , Processed in 0.168509 second(s), 13 queries , Gzip On, MemCache On.

Powered by Discuz! X3.5

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表