- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
窗体顶端
窗体顶端
窗体底端
Leverrier-Faddeeva递推算法的程序设计范例,编写程序实现基于塞尔维斯特准则的二次型标量函数的正定性判断。要求:编写程序设计报告,含:任务需求分析、程序流程、实现方法、测试验收、源代码等,
根据赛尔维斯特(Sylvester),可以通过判断对称矩阵P的定号性来确定二次型函数的定号性。
则
矩阵P正定的充要条件是所有的顺子主子式都是正的,即;
矩阵P负定的充要条件是
(三)程序设计流程图:
(四) 程序设计实现
输入:矩阵A,n阶方阵
输出:二次型标量函数V(x)是正定的、负定的、既不是正定的也不是负定的
结果
程序验证与测试
包含三个cpp文件
Mat.cpp包含类Mat的各成员函数、
Base.cpp实现矩阵的一些基本操作
包括:求行列式的值、
矩阵的余子式、
判断正定性
Mat.cpp
#include Mat.h
/********类Mat成员函数************/
void Mat::CreateMat(int r,int c,int type,double *A)
{
int i;
this-rows=r;
this-cols=c;
this-type=type;
data = new double[r*c]; //为矩阵申请(r*c)大小的内存空间。
if(A!=NULL)switch(type)
{
case INT:
for(i=0; ir*c; i++)//循环赋值
data[i] = (int)A[i];
break;
case DOUBLE:
for(i=0; ir*c; i++)
data[i] = (double)A[i];
break;
default:
data = NULL;
break;
}
else
{
for(i=0; ir*c; i++)//循环赋值
data[i] = 0;
}
}
void Mat::PrintMat()
{
int j;
if(data==NULL)coutendl还没给该矩阵赋值endl;
else
{
for(int i=0;irows;i++)
{
switch(type)
{
case INT:
case DOUBLE:
for(j=0;jcols;j++)cout”\t”data[i*cols+j];
default:break;
}
printf(\n);
}
}
}
double Mat::Read(int i,int j)
{
return this-data[i*cols+j];
}
(2)Main.cpp
#include base.h
void main()
{
Mat A;
int n;
double* a;
cout请输入方阵的维数:;
cinn;
a=new double[n*n];
cout请输入方阵:endl;
for(int i=0;in*n;i++)
cina[i];
A.CreateMat(n,n,DOUBLE,a); //创建矩阵 A 并赋值
cout原矩阵:endl;
A.PrintMat(); //输出原矩阵
coutendl;
Judge(A); //判断是否为实对数矩阵、正定性
// system(pause);
}
(3)Base.cpp
#include base.h
#include mat.h
//============用递归法求行列式的值(并返回)=================
double Fun( int n, double *a )
{
if(1==n)return a[0];
double* b;
double sum = 0; //i,j为行与列,sum为行列式的值
int x=0,num=0; //用x判断(-1)^(i+j)的正负
b=new double[(n-1)*(n-1)]; //数组用来存放代数余子式
for(int c=0;cn;c++)
{
for(int i=1;in;i++) //实现将余子式存入数组b中
{
for(int j=0;jn;j++)
{
if(j==c)continue;
b[num++]
您可能关注的文档
最近下载
- 北师大版八年级数学上册 1.1 探索勾股定理 同步测试(附答案解析).docx VIP
- 冀少版七年级上册生物全册新质教学课件(配2024年秋改版教材).pptx
- 卫生间改造施工组织设计.pdf VIP
- 《结构吊装施工》.pdf VIP
- 2025年中考数学押题:几何图形选填压轴题(含答案).pdf VIP
- 小学英语群文阅读:No Pain, No Gain 教学设计 PPT课件.pptx VIP
- 氢气管线吹扫试压方案.docx VIP
- 正余弦函数的图像和性质导学案.doc VIP
- 2021新教材必修第一册完美题型精讲(同步学习培优120个题型完美讲解).pdf VIP
- 美术五年级上册人美版 第2课 画人像(课件)(14ppt).pptx VIP
文档评论(0)